# COMPUTER STRUCTURES FOR DISTRIBUTED SYSTEMS LIAM MAURICE CASEY Doctor of Philosophy University of Edinburgh 1977 ABSTRACT: A building block approach to configuring large computer systems is attractive because the blocks, either primitive processors or small computers, are daily becoming cheaper and because this approach allows a close match of the power required to the power supplied. This thesis addresses the design goal of an expandable system where there is no premium paid for a minimal configuration and the cost of extra units of capacity is constant. It is shown that a distributed system, a system of homogeneous computers loosely coupled by a communication subsystem, is likely to be the best approach to this design goal. Some consideration is given to the form of the communication subsystem but the main research is directed towards the software organisation required to achieve efficient co-operation between the computers constituting the distributed system. An organisation based on the domain structures of protection schemes is found to have advantages. Hitherto domain management using capabilities has been centred around systems with shared primary memory. is because central tables have been required to implement the capability mechanism. A model is developed which, by restricting the sharing of some items and providing a 'global object' management scheme to cover essential sharing, enables central tables to be dispensed with and domain management to be distributed. The main goal in achieving this extension is to facilitate dynamic and efficient load sharing but the model could equally well be used to provide, in distributed systems, the protection normally associated with domains. This thesis also considers the wider ramifications of distributed systems. A simulation program is described and results from it are analysed to give some insights into factors affecting distributed system stability and performance. It is concluded that the above design goal of linear expandibility can be attained for a moderate range of systems sizes (perhaps from 1 to 20 computers). Keywords and Phrases: distributed computer system, multiple computer system, load sharing, homogeneous, domain, capability, simulation. #### ACKNOWLEDGEMENTS: Acknowledgement is due to the New Zealand Department of Scientific and Industrial Research whose generous financial support made this work possible. I wish to thank the supervisors of my study, Professor Sidney Michaelson and Nick Shelness. Also a word of thanks is due to Lee Smith who has assisted with the proof reading of this thesis. Finally I would like to thank my wife Hilary who has borne her 'Ph.D. widowhood' well. This thesis is dedicated to my son Martin. If it were not for his habit of waking early this thesis would not be completed yet. #### · DECLARATION: I hereby declare that this thesis has been composed by myself and that the work reported is my own. # CONTENTS | Chapter 1: | : PROLOGUE | · | |-------------|------------------------------------------|-------| | Chapter 2: | MERITS OF VARIOUS HARDWARE ORGANISATIONS | 12 | | Chapter 3: | : COMMUNICATIONS | 4] | | Chapter 4: | OPERATING SYSTEMS ARCHITECTURE | 62 | | Chapter 5: | THE DEVELOPMENT OF THE DOMAIN CONCEPT | 81 | | Chapter 6: | OUR MODEL | 106 | | Chapter 7: | DISTRIBUTED SYSTEM METHODOLOGY | . 141 | | Chapter 8: | DOMAIN MANAGEMENT | 176 | | Chapter 9: | DESCRIPTION OF SIMULATION | 198 | | Chapter 10: | RESULTS OF OUR SIMULATION | 230 | | Chapter 11: | EPILOGUE | 256 | | | | | | Appendix A | | A-1 | | | | | | Bibliograph | V | ъ.1 | # CHAPTER 1 PROLOGUE #### All our yesterdays: In 1954, a decade after the first digital computer was built, workers at the National Bureau of Standards, USA, connected together two computers, SEAC and DYSEAC, forming the first multiple computer system. The resulting system was capable, so they claimed, of handling efficiently problems which the two component computers could scarcely have handled if each were working alone [CODD62]. This led them to produce the first published proposal for the construction of a multiple computer system [LEIN58, CURT63]. The proposed system, PILOT, consisted of three computers: a primary computer, a clerical or secondary computer and an I/O computer. To quote: 'These computers intercommunicate in a way that permits all three to work together concurrently on a common problem and The system can be .... used in conjunction with other digital computer facilities forming an interconnected communication network in which all the machines can work together collaboratively on large scale problems that are beyond the reach of any single machine'. Despite the confident use of the present tense above PILOT did not achieve its design goals. It was decommissioned in the mid sixties, its construction (started in 1958) never fully completed although the hardware had been working well enough for 'continuing difficulties in using primary and secondary (computers) together, particularly in program debugging' to be experienced [PYKE74]. This thesis addresses some of the problems involved in getting computers to work together. Before PILOT the sole approach to achieving more computing power than that provided by a single machine was to build a faster machine. In a 1953 paper Grosch wrote: 'I believe that there is a fundamental rule, which I modestly call Grosch's law giving economy only as the square root of the increase of speed - that is to do a calculation ten times as cheaply you must do it one hundred times as fast' [GROS53] and Grosch's law, re-cast in the positive form as 'the power of a computer is proportional to the square of its cost' has in no small way encouraged this approach against that of trying to form multiple computer systems. Grosch's law did not go unchallenged [ADA462] but some ten years later it was given an impressive validation in the study of 225 American computers by Knight [KNIG66]. In a debate on the architecture for large computer systems in 1967 Amdahl, quoting Knight but conveniently ignoring a proviso he made about large systems in his work, exhorted everyone to 'Keep the faith, baby' in the single processor approach [AMDA67]. Amdahl has kept his faith to this day as has Grosch [GRUS76]. Some of the points we raise later (in chapter 2) suggest that there is considerable justification for their steadfastness. #### What tomorrow may bring: Nevertheless since PILOT there has been an increasing number of multiple processor architectures proposed and built. These architectures are justified as circumventing the current technological limits on the power of single processor systems, providing facilities to remote users (when the constituent processors are situated at geographically different sites) [BERN73,BLAN73,CRAI74], or providing more cost effective computing than single processors of equivalent power. This thesis is chiefly concerned with multiple computer architectures that may provide cost effective computing. The imminent prospect of cheap but primitive microprocessors and 'free' memory [WITH75] has led to an explosion in the size of proposed systems; systems '(of) over one hundred active processors' [GOOD73], 'having not tens or hundreds of processing elements but many thousands' [WIRC75] and '(forming) a network of thousands or millions of microcomputers .... a range of network sizes from 100 to 1,000,000,000 computers [WITT76]. In chapter 2 it is shown that queueing theory mitigates heavily against large numbers of low powered processors providing a service equal to that of a single processor with 'equivalent' power. Other chapters describe some of the mechanisms required for running programs on systems with modest numbers of identical computers, the overhead these mechanisms produce in each computer is shown, at best, to be proportional to the number of computers in the system. Thus the day of the million co-operating computers is never likely to arrive. Perhaps the most telling criticism that can be levelled both at PILOT and these later extravagant architectures is that the designers have concentrated only on the hardware requirements and given no thought to software required to achieve comperation among the Anyone attempting to implement one of these processors. over-blown systems would also experience continuing in achieving co-operation difficulties\* The mechanisms for co-operation have to be processors. formulated prior to detailed hardware design. The main research reported in this thesis has been on the software enable separate computers to structures required to single operational entity, a collaborate to form a distributed system. #### Cost effectiveness: This thesis describes a system that could consist from 1 to perhaps 20 identical computers. We feel that such a system may prove cost effective. For a given cost the system might provide more power than a single computer system or alternatively a given power might be provided by the multiple computer system more cheaply than by a single computer. We have used the word 'power' several times now without giving a definition, no satisfactory definition exists [FULL76]. The concept is meant to express the overall speed of a computer, how much work it can perform in unit time. Likewise satisfactory definitions of cost are impossible to formulate. So we will not add another deficient metric of cost effectiveness to the large number already in existence. Instead, we instance below recent examples of computer use that indicate that today Grosch's law is not valid and indeed may have been only a self-fufilling prophesy used by computer manufacturers to price their products. In 1973 Heart and others studied possible replacements for the IMP machines in the ARPA network [HEAR73, ORNS75]. The IMP machines perform a single function, namely the control of packet switching in the ARPA network. The amount of computing power this function requires varies depending on where the IMP is situated in the network. Heart and his co-workers, after performing simulations, concluded that systems constructed from upto 14 simple minicomputers would be cheaper than using a single faster machine. Using a multiple computer system they could also vary the number of computers in each IMP system to match the intended load, thus providing even greater savings. Schaeffer [SCHA75] has reported on a costing exercise that resulted in a chemistry department shifting its computing load away from a centrally run large machine to a 24 bit word minicomputer. The department's computing allowance bought them 32 hours of CPU time a year on a CDC 7600. The rate structure of the CDC 7600 reflected simply the cost of operation of the machine, its purchase price having been paid by an outside agency. Schaeffer found that the same annual budget would, over 4 years, pay the purchase price and running costs of a 16K word minicomputer. The minicomputer was purchased and the department's programs were found to run, on average, 35 times slower on the minicomputer than on the CDC 7600. Twenty hours a day operation of the minicomputer was achieved so that the department's annual budget purchased, in effect, 200 hours of CDC 7600 time instead of 32. Fuller (FULL76) has attempted a detailed comparison of the price/performance ratio of a PDP 10 and C.mmp, a system of up to 16 minicomputers [MULF72]. He encountered problems in defining performance and cost. He used two physical characteristics as measures of performance: instructions executed per second and processor memory bandwidth. The former is biased towards primitive machines that do little work with each instruction, while the latter is biased towards large machines which may in each memory cycle be fetching more data than they use. Therefore Fuller claimed, the two measures provided bounds for performance estimates and he calculated a factor of 4 in cost effectiveness of C.mmp against the most cost effective PDP 10 configuration. reports commercial have also been of There applications being mounted on systems of minicomputers at considerable savings over using single higher powered computers. A hospital in the USA has an operational system of 10 Data General Novas to perform all its data processing [CARR75]. Jagerstrom has described plans for a company to computerize by putting each application on a separate minicomputer [JAGE74]. He claims that the end system will be cheaper than if a single computer was used, with the added advantages that the computer power for each application need be acquired by the company only when it is ready to mount the application and, as in the case of the hospital above, some processing can proceed when one of the minicomputers has failed. It is not difficult to give reasons for the increasing hegemony of small computers. Large computers are characterized by low volumes of production and significant manufacturer commitment to software. Successful small computers sell in much larger quantities software support is lower, sometimes and their Software production is a fixed overhead non-existent. independent of the volume of sales. Expected sales volume dictates the fraction of this and other overheads, such as design cost and tooling up cost, which will be included in the individual selling price. production also affects the construction cost of each unit, greater volumes mean that more automated methods of production will be cost effective. The low volume of sales of large systems means that the same technology has to be retained over a long period to recoup the original investment. But older technology is more expensive per the se, and also in assembly costs because o f proportionally higher component counts [BLAK75]. course the cheaper computers are, the more will be sold. Overall there is a cascade of effects making small computers cost effective for more and more applications. The big question is whether or not small computers can be tied together to make more powerful systems that still retain their cost effectiveness. Does the overhead produced in amalgamating small machines into a larger one swamp the cheapness of the small machines? A building block approach [DAVI72], where identical computers are added to a system until the required power is achieved would be beneficial both to manufacturers and Manufacturers are often required to produce a range of computers of identical architecture power. Each type of computer requires differing designing afresh and may be implemented using different semiconductor technology from the other types, thus negating many of the benefits of large production volumes. Using a number of low power computers to fabricate the computers at the high power end of the range means that only one design is needed and this will be produced in extra large volumes. The user, unless he buys a computer for a single static task, has to be aware of the cost of obtaining an increase in capacity as his This usually leads requirements increase. him to purchase a system with capacity in excess of his immediate needs and may later involve him in having dispose of some hardware and buy a more powerful system if his requirements grow too large. Buying a system exactly matched to his needs and expanding it contracting it) when those needs change, by altering the number of building blocks, can provide obvious economies for the user. Both manufacturers and users would be looking for systems with low initial cost and linear expansion costs. If, because of the requirement of being expandable, a small system costs a lot more than an equivalent non-expandable system then it will be difficult to sell the expandable system. Likewise a system where added building blocks become less and less cost effective because overall performance diminishes as extra building blocks are added, would be limited in usefulness. is required is a fixed cost/performance ratio. marginal increase in power with the addition of an extra computer should be constant (or nearly so) no matter how many computers there are already in the system. There is often an expectation of general synergism in multiple computer systems, that is the total power in the system is expected to be somehow greater than the sum of the individual computers' powers. While there can be limited synergistic effects as a system expands, overall the total power available is just that provided by the constituent computers. It is impossible to provide indefinitely a diminishing cost/performance ratio as the number of computers in a system grows. In the next chapter we look at the two basic ways of amalgamating computers: multiprocessor systems, where primary memory is shared between all processors, and distributed systems, where computers are kept separate but interact with one another using some form of communication system. We describe the drawbacks of both multiprocessor architectures and single processor architectures compared to distributed systems and the rest of the thesis concentrates on distributed systems. Chapter 3 examines the various forms the communication system can take and chapter 4 looks at operating systems structures suitable for distributed systems. Une of these operating system structures, the kernel/domain architecture is further described in chaoter 5. The rest of the thesis then details facets of the design of a distributed system using the kernel/domain structure and describes a simulation program that was used to study some performance questions that arise concerning the design. #### CHAPTER 2 #### MERITS OF VARIOUS HARDWARE ORGANIZATIONS A useful taxonomy of computer architectures has been defined by Flynn [FLYN72]. He divides systems into 3 types: - SISD: (single instruction acting on single item of data) the conventional uniprocessor system. - SIMD: (single instruction acting on multiple data items) systems with vector hardware, associative and parallel processors. - MIMD: (multiple instructions acting on multiple data items) multiprocessor systems and computer networks. (For completeness there is also the MISD type, which others have taken to denote instruction pipelining machines (HIGB73, THUR751). Systems of the SIMD type have been the chief candidates for solving large scale problems beyond the limit of conventional machines. They have always been one-off and economics would seem to be a secondary consideration in their construction. It is now generally conceded that there are some special problems, weather forecasting being the most often quoted example, for which these architectures are the most appropriate but "these are special-purpose machines and any attempt to apply them to an incorrectly sized, or designed, problem is an exercise in futility" [[HUR/5]. There is a spectrum of MIMD systems, ranging from tightly coupled multiprocessors systems to trans-world networks. The system that is described in this thesis is a network that lies towards the multiprocessor end of the MIMD spectrum. It consists of a number of homogeneous (that is highly compatible, if not identical) sites connected by a communications subsystem. The whole system is envisaged to be local in extent, fitting into a cabinet, a room or, at most, a building. Each site is assumed to consist of a single processor with its own The term 'distributed system' has been memory space. arbitrarily appropriated to denote this. There is no logical reason why the sites in a distributed system should not each consist of multiprocessor systems, but to avoid confusion we do not consider such a case here. To place distributed systems in context we examine the benefits and drawbacks of MIMD systems compared to SISD systems, particularly in relation to time sharing. In order to gain mathematical tractability, queuetheoretic models are always idealized abstractions that omit many of the details of reality. The results of queueing analysis nevertheless often indicate fundamental constraints that cannot be breached by any strategy. #### Organizations: In a queueing theory approach to hardware organization the differences between architectures are represented by replicating servers and by having different queueing mechanisms. Figures 2.1 to 2.7 give the representation of various systems each having a total service capacity of C operations per second and each having an overall arrival rate of jobs, requests for service, of $\lambda$ requests per second. We assume that the mean number of operations requested by each job is $1/\mu$ . To ensure that the systems have the capacity to ultimately deal with all jobs arriving the further assumption is made that $\lambda/\mu$ C < 1. The ratio $\lambda/\mu$ C is called $\rho$ , the utilization, as it gives the ratio of the mean number of operations requested of the system per second $\lambda/\mu$ to the number of operations the system can perform per second, C. The SISD architecture, the single processor system is represented by figure 2.1. This is the classical single server queueing system, the backbone of queueing theory. Single processor Figure 2.1 Multi processor Figure 2.2 Distributed system with instantaneous jockeying Figure 2.3 Analytic expressions for the mean response time, I, that is the average elapsed time between job arrival and job completion, have been found for large classes of probability distributions of the arrival rate and service times of jobs, and for a number of queueing disciplines such as first come first served, round robin and so on (see for example KLEI75, KLEI76). The simplest case is for first come first served systems where both the inter-arrival times between jobs and the size of jobs have (negative) exponential distributions. The mean response time is given by $$T = 1/(\mu C - \lambda)$$ The tightly coupled multiprocessor system, with N processors is represented by figure 2.2. In the multiprocessor system it is assumed that service of jobs is from a common core queue. Analytic results are known for T only when the service time is exponentially distributed [KLEI74]. For the case of N=2 with exponential arrival times the result is $$T = 2\mu C/((\mu C + \lambda)(\mu C - \lambda))$$ Figure 2.8 gives graphs (adapted from [KLEI74]) for the normalized response time (when $\mu$ C=1) for N=1, the single processor case, N=2 and N=10, assuming exponential arrival and service times. There is an approximate solution, Kingman's conjecture, for T for general distributions of arrival times and service times, for when $\rho$ is close to 1, given by $$T = N\rho/\lambda + (C_a^2 + \rho^2 C_P^2)/2\lambda(1-\rho)$$ where $C_{\alpha}^{\lambda}$ is the squared coefficient of variation of the inter-arrival times and $C_{\rho}^{\lambda}$ is the squared coefficient of variation for the number of operations required by a job [KLE174]. Figure 2.3 shows a queueing system that has separate queues for each server but is subject to 'instantaneous jockeying. The last entry in a queue moves instantaneously to another queue if that queue becomes shorter than the queue it is in. This represents the ideal, physically unattainable, for load levelling distributed systems. Because such systems do not share core they do not have a common queue of jobs, but if the distributed system wants to keep the load on all processors the same, then jobs will be moved around to try to attain this. In the real world moving jobs will take some time, during which the load situation could change again. Instantaneous jockeying means that no processor is idle when another server has jobs waiting for service. It has been shown that because the idle time of servers is the same as in the common queue system above that the mean service time will be the same as well [LEEA66]. we make a distinction between load levelling, where jobs are moved about from queue to queue, and load balancing where the system attempts to even out the load on each server solely by directing incoming jobs to the queue of the server that is most likely to be able to Distributed system: go to shortest queue Figure 2.4 Distributed system: order of arrival Figure 2.5 serve them first. Figure 2.4 depicts the system where incoming jobs are allocated to the processor with the shortest queue, and the job remains in that queue. Obviously in this situation it is possible for one server to be idle while another server has jobs waiting, hence the utilization of servers will be lower than in the common queue or instantaneous jockeying system, and the average response time will be higher. Definite formulae for T have not been derived. Figure 2.5 represents the situation where arriving jobs are allocated to each server in turn, irrespective of load. We would expect this to give worse response times than the case above where jobs go to the processor with the shortest queue. The arrival rate of jobs at each server in this case is $\lambda/N$ and the squared coefficient of variation of the arrival times is $C_q^2/N$ . In the case of exponential arrival times the effective arrival time distribution for each server is N stage Erlangian, a situation that has been solved analytically when there is exponential service times. More generally if we consider Kingman's approximation we have $T = N\rho/\lambda + (C_q^2 + N\rho^2 C_p^2)/2\lambda(1-\rho)$ Thus the increase in response time over the common queue system is confined to the term $N_\rho^2$ $C_\Gamma^2$ and so depends on the number of servers and the coefficient of variation of the number of operations required for each job. If each job requires exactly the same number of operations (i.e. $C_\rho^2=0$ ) then there would be no increase in response time using this allocation of jobs to each server in turn instead of using a common queue. Unfortunately in computer systems the coefficient of variation of service times is likely to be large. Figure 2.6 represents the extreme situation of no coupling at all between systems. The population of jobs is divided into N categories a priori so that the arrival rate at each server is $\lambda/N$ and the squared coefficient of variation remains $C_q^2$ . This type of system can arise when the users are divided into N equal groups and each group is permanently assigned to one computer. It also arises when functionally specialized computers are used so that each server can only handle one type of job. We assume here that there are N types of job and that the overall average number of each type of job is the same. In this case the response time is exactly N times what it would be for the single server with capacity C because each server is an independent server with capacity C/N. the case of exponential arrival and service times the average response time is given by $$T = N/(\mu C - \lambda)$$ If the average fraction of jobs going to each server is not identical for all servers then the same mean response time (but not the same variance) will be obtained if the capacity of each server is adjusted to be in proportion to the average number of requests received by that server (keeping the overall capacity equal to C). Separate systems Figure 2.6 Pipeline Figure 2.7 Figure 2.7 shows a pipeline or N stage tandem system. Here we assume that each job requires an average service of $1/N\mu$ operations from each server in turn. In the case of exponential arrival and service times Burke's theorem [KLEI75] states that the mean response time is given by $T = N/(\mu C - \lambda)$ which is the same as the completely decoupled system above. #### Implications: Our excursion into queueing theory results has shown that the various ways of configuring systems to give a capacity of C operations per second do not all give the same response times. Figure 2.8 shows the deterioration in response time (normalizing $\mu C$ to unity) as the capacity C is divided among 1,2 and 10 servers, the 2 and 10 server systems either taking jobs from a common queue or having instantaneous jockeying. These response curves were drawn under the assumption of negative exponential arrival and service times, but similar curves could be the Kingman approximation. using drawn unequivocally show that unless the utilization ho is very to 1, when response times are very long anyway, having a single server gives better response times than dividing up the capacity among N servers. For batch processing systems it is possible to attain a processor utilization close to 1. To attain reasonable response times for time shared systems an operational range of utilizations is likely to be in the region of 0.6<p<0.9 [BELL70]. For such an operational range replacing a single large processor by a number of microprocessors, say, of the same total power (ignoring overheads) is going to result in worse response times. If other considerations lead to the adoption of multiple servers then the results presented above indicate that an effort should be made to maximize the utilization of servers. Systems where no server can be idle while there are jobs waiting for service, the common queue and instantaneous jockeying systems above, have a better mean response time than systems where there is a possibility of servers being idle while there is outstanding work. Specialization of servers so that each can only serve a subset of jobs, or so that every one of them has to be involved in the service of all jobs, gives the worst response time. Thus the above analysis indicates that there are increasing gains to be made by - 1) accepting any job at any server (processor) - 2) attempting to load balance by directing incoming jobs to the shortest queue - 3) attempting to load level by shifting jobs from the ends of queues to shorter queues. As we stated in chapter 1, the expansion characteristics of a system are important. Figure 2.9 depicts the normalized response time for three systems, each with exponential arrival and service times. The N=1 system has a single server of capacity C and an arrival rate of requests $\lambda$ . The N=2 and N=10 systems have 2 and 10 servers respectively, each server having a capacity C, and the arrival rates at these systems are assumed to be $2\lambda$ and $10\lambda$ respectively. (Again equivalent curves could be drawn using the Kingman approximation). Figure 2.9 shows a pleasing feature of expansion of the number of servers while keeping the load per server constant; in the time sharing operational range mentioned above there is a decrease in response time. The minimum possible mean response time is simply the mean service time and this is attained, for all values of $\rho$ <1, when there is an infinite number of servers. So the decrease in response time, as another server is added, tends to zero as the number of servers becomes large. # Queueing networks and bottlenecks: A closed network queueing system consists of a finite number of jobs (customers) that cycle around queueing for service at a number of nodes. After a job has received service at a node it moves to another node to queue there for service. Closed network queueing systems can model the behaviour of time sharing systems better than the models we discussed above. The fixed number of jobs represents the restrictions in time shared systems on the total number of concurrent users. Resources other than the central processor, such as disks, from which there is a requirement for service can be represented as nodes in the network system. After Moore [MOOR71] analysed the MTS time sharing system using a closed network queueing model, a rash of papers appeared applying closed network queueing models to the study of time sharing systems. These efforts are surveyed by Kleinrock [KLEI76]. We will not discuss them further except to examine the concept of the 'bottleneck'. When a system has more than one type of resource in demand, then as the load on the system is increased (by increasing the number of jobs in the system), utilization of the resources will increase. the utilization of some resource will get very close to 100% so that the utilization cannot increase significantly as the load increases. At this stage a long queue containing almost all of the jobs in the system will build up waiting to use the resource. This resource is a bottleneck and the overall response time of the system becomes completely dominated by the response time of the bottleneck. (The response time analyses we gave above are valid therefore when processing power is bottleneck in a system). A system where the the utilization of all resources approach 100% together is called a balanced system. #### Memory requirements: Recently Borgerson [BORG76] has examined another facet of replacing a single processor with N slower processors to give the equivalent capacity. He considered a single processor system that achieved adequate processor utilization when it had enough primary memory to sustain a multiprogramming level of K (that is K jobs, or working set, could reside in the primary memory at once). By a very simplistic analysis he determined that the 'equivalent' multiprocessor system (with N processors) would require enough primary memory to contain N+K=1 jobs to achieve the same processor utilization. Certainly N processors cannot all be gainfully employed processing K jobs if K is less than N. The longer response times of N processor systems translate into longer job residency in primary memory. # Adequacy of queueing theory models: Queueing theory does give some very useful insights into how various systems will behave. But there are restrictions placed on service times, queueing and service disciplines, and particularly interactions between different resources in the system (e.g. queueing theory cannot model the constraint that both primary memory space and a processor have to be available before a job can be executed). In consequence queue theoretic approaches cannot be used for detailed analysis of systems. Perhaps the last word should go to Kleinrock, whom we have used as a source for many of the results quoted in this section. The mathematical structures ... created in attempting to describe real situations are merely idealized fictions, and one must not become enamoured with them for their own sake if one is really interested in practical answers' [KLE176]. # SECTION 2: PHYSICAL AND CUST CONSIDERATIONS. There are of course many factors besides queueing theory predicted performance to be taken into account in considering an architecture. Cost effectiveness is the paramount factor. We now look at a number of factors that affect the cost or performance of various architectures. #### Overheads: The computation required to manage a list or queue grows at a faster than linear rate as the size of the list or queue grows [HANS73]. Thus the overheads in managing a system with a large number of users are proportionally much greater than for a system with a small number of users because the former will have longer queues. A multiprocessor system and a single processor system of equivalent power will have approximately the same management overheads (but there will be some added complexity in dealing with multiple processors). However in a distributed system some of the lists and queues are partitioned amongst the sites so that there is a reduction in the overheads of managing them. Some part, perhaps all, of an operating system must be resident in the primary memory of a computer at all times, using up memory space that would otherwise be available to user programs. In a system with multiple servers which are not completely independent, extra operating system software is required to achieve the among the servers [BORG76]. necessary comperation However in a multiprocessor system only one copy of operating system is shared among all the processors. This impacts favourably on the expansion characteristics of a multiprocessor system because added memory can be almost entirely dedicated to user programs. In all multiple computer systems that we know of that do not have shared memory, apart from the system we develop in this thesis, each computer has its own complete, or nearly complete, operating system. Une of our chief aims has been to make as much software as possible shared among all the sites in our distributed system so that increasing the size of system means that proportionally more primary memory space is available for useful work. #### Parallelism: in the queueing theory analysis above each and every job presented to a multiserver system could be split into exactly N parallel phases of equal duration, one phase for each server, then the response times of the multiserver system would be equal to that of equivalent capacity single server. However, apart from such operations as overlapping I/O with processing, parallelism in general purpose computing is difficult to find, both at the macro level and the micro level Examples of programs decomposed into parallel [TJAD70]. modules [THOM72, FULL 76] seem to us rather to be We do not think that parallelism can be contrived. relied upon as a factor to bring the performance of multiple processor systems up to that of single processor systems. # Functional specialization: Many designs for distributed systems and multiprocessor systems utilize functionally specialized processors [JUSE74,COLO76,ARDE75,FABR74,REYL74,SELI72]. Computer networks of large machines, usually at separate locations, are often justified by the differing characteristics, hardware or software, of each computer, or host, in the network [RUBE70,GHE273,COLE73]. the case of networks joining together already In existing machines, functional specialization does offer potential for increased throughput and perhaps reduced response time, compared to the original situation of not having a network at all. This is because if each host is offered highly conformable work it can process it faster than if it has to process all types of job. close co-operation, such as load levelling or balancing, although often cited as design goals for networks [ROBE70, HOWE72] have yet to be realized. Basically the overheads in achieving closer co-operation [HICK71, SMIT72, FRED731 outweigh the benefits. We feel functional specialization will continue to be the raison d'etre of geographically dispersed networks of large computers. In the case of distributed systems and multiprocessors the gain in effective capacity through functional specialization has to be very large to offset the queueing theory gains in response time that can be achieved by making all processors capable of executing all jobs. Functional specialization often gives rise to very simple forms of operating systems, usually of the hierarchic [REYL74,RUWA74] or pipeline variety [FARB74]. But the overall system can be very inefficient. The average response times we quoted above for functionally specialized servers are valid only when the distribution server capacities exactly matches the o f characteristics. If there is a mismatch then the average response times will be worse. Thus there is the problem of determining the exact characteristics of the workload on a system and making sure that it stays stable over Obtaining a balanced system and expanding it in a balanced fashion is not easy for small systems. hierarchical, or star, systems the central supervisory processor which allocates work to specialized servers is likely to be underutilized there is to be any slack capacity for expansion) making the system non cost-effective. For large systems where each type of server is replicated many times balance is easier to achieve and the theoretical response time approaches that of a system with homogeneous servers, because the overall load at any particular instant vary far from the average load [KLEI74]. hierarchical systems though, the central node is likely run out of processing power so that it cannot handle the allocation of work to specialized servers fast enough to keep them busy. All hierarchically organised multiple processor systems, ones with a supervisory processor, suffer from the twin problems of underutilization of the supervisory processor, and hence diminished cost effectiveness, in small systems, and eventual debilitating inadequacy of supervisory processor capacity as the system grows large. Since our stated aim is low cost small systems with linear expandability we do not consider hierarchical systems further in this thesis. As for functional specialization, we believe that the types of processor that will be manufactured in the greatest volumes will be general purpose processors. Referring back to our discussion of manufacturing costs in chapter 1, general purpose processors therefore will cost the least. So, because of their likely low cost and definite advantages in small systems, we concentrate on systems containing homogeneous processors and ignore functional specialization. It so happens however that the design we develop in this thesis can quite naturally handle functional specialized computers, as we show in chapter 7 when we discuss peripheral handlers. #### Availability: In theory both multiprocessors and distributed systems should be capable of graceful degredation as components fail. In practice, for general purpose systems, this is likely to be translated into high availability; a failing component need only be isolated, not repaired, before the system, with reduced capacity, can be used again. The single processor system is completely unusable in the event of a processor fault until the fault has been repaired. In the production of highly reliable computers, distributed systems and multiprocessors can be used more effectively than double or triple replication of a single processor system. There are however special techniques involved in the attainment of high reliability [SCO[74], which we are not going to pursue in this thesis. ### Large single processor systems: From the queueing theory results above a single fast processor system would seem to be the best choice. There are however two points that need considering in relation to the queueing analysis: - 1) Frequently large computer systems cannot be reasonably modelled as a single queue for processor service. Often channel capacity is a restricting factor and even if the system is balanced it is unlikely that there will be a single channel of sufficient capacity, rather there will be a number of channels (probably specialized) of lesser capacity so the poorer response characteristics of multiple servers could occur anyway. - 2) The initial assumption in the comparisons was that the single processor was uniformly N times as fast as each processor in an N processor system. However it is unlikely that the single processor will be N times as fast at context switching. As a processor gets faster it uses more and more fast registers which will have to be saved (or drained when pipelines are used) on context switching. To avoid too frequent context switching large systems use peripheral processors, communications processors and/or front end processors; hence incurring some of the disadvantages associated with multiple servers and functional specialization. Even with these aids a greater proportion of computing capacity is still likely to be wasted by context switching in the single processor environment than with slower processors where the 'opportunity' loss on a context switch is much smaller. If it maintains its single server characteristics the large scale single processor system offers superior performance in general purpose computing compared with other architectures of equivalent capacity. But when the above factors are combined with the cost considerations we described in chapter 1, and the poor availability and expansion characteristics of single processor systems we see that the case for overall superiority is not so clear cut. Considering that they give relative ease of expansion, high availability and the possiblity of achieving a capacity not technically feasible with a single processor, multiprocessor systems and distributed systems are certainly worth investigating. The distinguishing characteristic of a multiprocessor, shared memory, gives the multiprocessor its its advantages over distributed systems. These advantages are greater speed of interprocessor communication and larger size of contiguous memory. In a distributed system the various sites can only co-operate by sending messages to one another, which takes a longer time than using shared tables and semaphores in multiprocessor systems. (But since, for example, the processors in a distributed system do not have to co-operate over the management of shared primary memory, the inter processor communication mechanisms will be invoked less frequently than in multiprocessor systems). A large contiguous memory usually leads to greater efficiency in handling large problems [WITT68]. The packing problem, fitting complete jobs or working sets into available memory [AGRA75], is obviously less severe for one large memory than for a number of small memories. Shared memory is also responsible for the poor features of multiprocessor systems: expensive and expansion limiting memory access circuitry, contention and software lockout. In a multiprocessor system more hardware is required to provide access to shared memory (and to peripherals). The access speeds to memory will be slowed either by the inclusion of a crossbar switch (with high initial cost and inflexible limit to expansion) or a bus for which processors have to bid. Alternatively the memory units can be multiple ported making them more expensive and again limiting expansion [SEAR75]. Memory contention occurs in multiprocessor systems when a processor cannot access a word of memory because some other processor is using the access circuitry. partial solution to this can be expensive; replicating access circuitry by providing storage in modules and then providing interleaving circuitry so that accesses 'random'. With random access in a system where the number of processors is equal to the number of memory modules the utilisation of processors and memory falls quickly to 50% as the number of processors is increased [BHAN73a, BHAN73b, BURN73, BASK76]. However if the access time for a word is far shorter than the average time process the word, as is likely to occur if MOS/LSI microprocessors are used LREYL741, then the effects not be as severe as this. high performance With processors obtaining the necessary extra memory bandwidth to reduce contention could be costly. Cache design for multiprocessors is difficult [TANG76] and of dubious efficacy. In contrast caches can easily be employed in single computers that constitute a the processor distributed system, if they are required. In multiprocessor systems software lockout occurs [MADN68]. Processors executing certain parts of the operating system will need to alter tables or have unique access to some resource. Other processors executing the same code will have to wait for the previous processor to finish. This problem can be ameliorated by setting many locks, each held for very short periods of time but then the cost of setting the locks begins to erode efficiency. The two most publicised multiprocessor systems with more than two or three processors are C.mmp [WULF72, and Pluribus [HEAR73,ORNS75]. WULF74al systems try to circumvent the problems of shared memory by providing all processors with private memory as well. Pluribus is a special purpose system and the decision as to what goes into shared memory and what goes into private memory is a static one taken at design time. the case of the general purpose C.mmp system there does not seem to be any methodology developed for using Private memory is a partial private memory. only solution to the above problems anyway, it lessens the amount of contention but does not significantly affect software lockout or the cost of the access circuitry. A system developed to work where there is no shared memory could easily be adapted to a situation where some of the memory is shared, but the converse is not true. So it makes sense to develop a distributed system and then see if some form of shared memory will improve performance while not degrading the expansion capabilities of the system. We raise this topic again in chapter 11. With an appropriate communication subsystem and software organization a distributed system can exhibit most of the advantages a multiprocessor system has over a completely decoupled system of computers, while avoiding the limiting effects of shared memory. The next chapter examines the required features of a communication subsystem and chapters 4 to 8 are devoted to the development of the software organization. Features of the distributed system we propose are: - 1) It is a unified system with respect to peripherals. - 2) Each memory is private to one processor. Low speed memory, matched to processor speed, can be used and there will not be any contention, bus or switch delays. - 3) Less memory is required than for the same number of independent computers because one copy of most of the operating sytem is required for the whole system. - 4) It is very modular, easily expandable and has high availability. - 5) A form of software lockout will occur but it will probably involve less wasted processor capacity than software lockout in a multiprocessor system. Delays will arise when a component of the operating system that is shared between sites is required simultaneously at two sites. However the waiting time need not be unproductive; the waiting site can do other work if there is any outstanding, in contrast to the 'busy' wait required at the low levels of multiprocessor operating systems. - 6) Some of the management software will be as simple as that required if each site were an independent single computer, although other software will be as complex as that in multiprocessor systems. - 7) There will be a communications overhead, which is not present in multiprocesor systems. - 8) The response characteristics will be almost those of a multiprocessor system because the software structure comes close to implementing 'instantaneous jockeying'. ## CHAPTER 3 #### COMMUNICATIONS A distinguishing feature of distributed systems is that co-ordination and control of processors is performed by messages rather than by the use of common tables. Since we wished to study the software structures needed to ensure co-operation between the sites in a distributed system, our initial reaction was that the form of communication subsystem for passing messages between the sites was immaterial to our problem. However we soon came to realize that the properties of certain types of communication subsystem could have a significant effect on the nature and efficiency of some of the software mechanisms required. This chapter investigates what kind of interconnection structures, communication subsystems, are appropriate for distributed systems. In a distributed system there are two types of communication, one, which we refer to as a message, is intended for one site only while the other, which we call a broadcast, is received by all sites in the system. Messages arise chiefly in the transmission of data and code between sites. Broadcasts can be used to propagate information about the overall state of the system. First, we examine types of communication subsystem and then, in section 2, we examine how the type of communication subsystem impacts upon the flow of information in the distributed system. ## SECTION 1: COMMUNICATION SUBSYSTEMS. There are a number of criteria that we can use to distinguish the various types of computer interconnections, existing or planned [ANDE75, CHOU75, SEAR75]. For our distributed system we are looking primarily for low initial cost and expansion costs directly proportional to the number of sites in the system. Since we propose our computers to be separated by physically short (although electrically long) distances we do not require the existence of alternative routes between sites. Nevertheless we do not want the failure of a site to disrupt the communications between other sites. It is also desirable that the logic required for directing messages to their final destination be simple. Centralized (star) communication systems (figure 3.1) undoubtedly offer easy routing but their cost is not Star Communication System Figure 3.1 Figure 3.2 proportional to the size of the network. The central be it a processor or other device [CULU76], is switch. required whether there are two or twenty computers in the Further if this switch is going to have system. sufficient capacity to allow for reasonable expansion then it is going to be underutilized for small systems, probably making the small distributed system unattractive compared with an equal cost single processor system. method of expanding the capacity of the central switch has been proposed by Goodwin [GOOD73, ANDE75]. He wanted to replace the centre switch by a whole tree of lower capacity switches (figure 3.2), expanding the size of the tree to give greater capacity when required. The cost is logarithmically proportional to the number of leaves (the computers doing the useful work) and the direction algorithm is simple. But unless (undesirable) measures are taken to confine most communication to be between leaves that are close to each other, on average (n-1)/n of the messages will pass through the root switch when there are n nodes connected to it. Thus for message transmission at least, a tree structure gains little over a star network in capacity and introduces substantial delays to achieve this. Of the non-centralized interconnection schemes a distinction can be drawn between those where the message travels directly to its destination without being copied and retransmitted, and those where a message travels in stages. The latter is often the preferred method in trans-world type networks [ROBE70, KLEI70, POUZ73, HIRC74] where the complexity of routing is justified by the reduced cost and enhanced reliability of transmissions. The only simple structure of this type is the loop and as this meets the criteria of expandability and linear cost we will study it further, along with the two kinds of direct distributed communication subsystem: complete connection and shared bus. # Complete connection: A complete connection communication subsystem (figure 3.3) was proposed for the Karoline network [MADS72]. For small systems it has favourable features. Most computers have a few unused peripheral slots and simple links are cheap and quite easy to construct [LIND71] making initial cost low. There are no routing problems. Flow control, ensuring that there are not too many messages in the communication subsystem simultaneously, is not required as each link involves only two computers. An inoperative computer does not affect the links between the remaining operational computers. The total bandwidth grows as the number of computers in the system grows. Expansion is not directly limited but it does get progressively more The nth computer added requires n-1 links. Karoline being a network of 8 machines required 28 links. Bearing in mind that the links are probably quite cheap compared with other resources in the network, 28 links Completely Connected System Figure 3.3 Figure 3.4 could well be the best form of communication system. Broadcasting however, will usually consist of separate sequential transmissions to each of the other sites. This will present a greater load on the sending site than systems where a broadcast involves only one transmission. ### Loop: DCS system [FARB72a], the initial version of the Maryland DCN project [LAYM74] and the Waterloo Mini-net [MANN75] all use a loop or ring communication subsystem as depicted in figure 3.4. In a simple form a ring a cheaper alternative to the complete system is connection system. For n sites n links are required and each site requires only one send slot and one receive slot. A site sends a message to its neighbour which decides if it is the message's destination or not. If it is not, then the message is passed on to the next neighbour. When a message has reached its destination it can be removed from the system (Maryland DCN) or marked received, a copy kept, and allowed to circulate back to the sender (DCS). This later option provides an automatic though expensive acknowledgement. Given that this complete loop traversal is to take place, broadcast involves the same overheads as a message. A message however causes interruptions to all sites it travels through and so sophisticated ring systems such as DCS use special units, ring interfaces, one for each site. Each interface unit buffers messages and only interrupts its site if the message is for it [REAM76]. With intelligent design, the ring interface units also overcome the problem of the whole loop becoming inoperative should one computer in it fail: in such circumstances the ring interface unit can simply pass all messages on. The use of special units means that beneficial features, discussed in section 2, can be added. The total bandwidth of a loop system is fixed. As more computers are added the bandwidth available to each decreases and the average time for a message to reach its destination increases. Since there can be a number of messages in the loop the question of flow control arises. If a site puts a new message in the loop without regard for messages that may arrive and require retransmission, messages will have to be destroyed. Simple forms of flow control can involve considerable loss of bandwidth. flow control schemes of some loop systems have been evaluated by Reames and Liu [REAM76]. The Newhall loop uses a round robin, token to send new message, scheme. A site can only introduce new messages into the loop when it has the token, it sends the token onto the next site in the loop at the end of its new messages. The Pierce loop divides the bandwidth into fixed size slots or 'message crates' and a site can send a new message if an empty crate is passing through its interface unit. Unless messages are all the size of slots or less, they have to be broken into packets with all the attendant problems of disassembly, sequencing, buffering and reassembly (FRAN72). The DCLN loop of Reames and Liu uses buffers in the interface unit to hold incoming messages (that have to be retransmitted) while new messages are introduced into the loop. Thus any site, providing its buffer has space equivalent to the length of the new message, can introduce a new message almost immediately. Although transmission time around the loop is increased it is shown by Reames and Liu that, overall, messages arrive faster than in the other two schemes because they do not have to wait so long to enter the loop. If it is desired to stop an errant computer from monopolising the available bandwidth a distributed control scheme leads to further loss of bandwidth. In the DCS system control over runaway sites takes the form of the ring interface units permitting each site one outstanding message at a time [FARB72c]. ### Shared bus: The KOCOS system [AISO75] uses a conventional 32 bit wide bus while Ethernet [METC76] is a serial bus of particularly simple construction. For the distributed Shared Bus System Figure 3.5 use of a bus some interfacing unit is mandatory (figure 3.5). KOCOS uses one which also aids in controlling interprocess communication [WALD72]. Ethernet interface does not have extra functions but would, with the addition of an associative memory function, come closest to what we think would be the ideal type of communication subsystem for a distributed As it stands it is an adaptation of a type of ALDHA net [ABRA70, BIND75] with 'radio' transmission constrained to be along about 1 Km of co-axial cable. The interface units have a policy of deferment; they will not start transmitting a message if they detect a transmission is in progress. This means that collisions (and subsequent aborting of transmissions) can only occur in the first part of a transmission, in the period equal to the round trip time - for Ethernet less than 8 microseconds. With long packets, 4096 bytes, and the use of a 'quadratic back-off' policy when transmitting after collisions, a utilization of the communication subsystem of over 95% is expected when it is heavily loaded. [METC76]. Unlike KOCOS which has a round robin policy for control of the bus, in Ethernet any site can send a message immediately if the communication subsystem is not already in use. The total bandwidth of a bus is limited but, unlike the loop, there is not an increase in message transmission time as more sites are added. Flow control in KOCOS is provided by the round robin scheme while in Ethernet it is done by a back-off policy whereby if messages collide retransmission is not attempted for a random period, the mean of which increases with the recent collision rate. A broadcast in a shared bus system can be effected with a single transmission. Suitable design of interface units can ensure that the bus is not brought down by the failure of a site. SECTION 2: INFORMATION GATHERING. Global object management: As will be described in detail in later chapters, there are certain objects in the distributed system that are global; any site must be able to locate the sites where these objects currently reside. As the size of a distributed system goes up the movement of global objects between sites will increase. Thus we need to be concerned with the efficiency of management of global objects. There are several ways that the location of global objects can be determined. - 1) Continuous updating: Every time a global object moves a broadcast of the form "X has moved to site I" is performed. Each site has a directory of global objects which it updates when it receives the broadcast. - 2) Central directory: Une site is specially designated as a directory site. Each time an object moves a message of the form "X has moved to site I" is sent to the directory site. To determine the location of an object a site sends a "where is X" message to the directory site which sends a return message "X is at I". So one message is sent every time an object moves and two are required to determine its location. central directory is in some sense antithetical to a distributed system. However there exist schemes for nominating a new site as the directory holder should the old one fail [TYME71] and a directory can quickly be reconstituted with a broadcast of "What global objects do you have". We cannot escape the fact that part of the directory site's workload will inherently different from the rest of the distributed system (perhaps causing problems with load balancing). Should this workload prove to be a bottleneck then a hybrid system with a number of directory sites using continuous updating amongst themselves can be used. Each directory site would service a different set of non-directory sites. So an object move generates message to one directory site and a 'limited' broadcast from that directory site to all other directory sites. - 3) Search: No directories are held at any site and there are no updating messages or broadcasts when a global object moves. Instead, in this scheme every time a site wants to know where an object is it broadcasts "where is X". The site where the object resides replies with a message "X is at my site". - 4) Associative: The only reason a site can have for wanting to know the location of a global object is so that it can send a message (related to the object) to the site the object is at. An alternative form of the search scheme is simply to broadcast the relevant 'message' and have each site decide if the broadcast is related to any global object currently residing at Although this form of search involves less messages than the other, the length of the broadcast is likely to be a lot longer. Hence direct broadcasting is only appropriate when a broadcast involves the same load on the communication subsystem as does a single message, namely when systems have interface units. A direct broadcast scheme can be made most attractive by the use of extra hardware in the interface units. If an associative memory, containing the names of all the global objects at a site, is attached to the message receiver at each site then the decison to accept a broadcast can be made without reference to the main processor [FARB72c]. There is no need for directories to be kept, or updating information broadcast, when objects move. There is no delay when a message has to be sent to (the site at which resides) a global object and sites are not continually being interrupted to answer "Where is X" broadcasts. Whether an associative memory is used or not, direct broadcasts require care with synchronization; the global object may be in transit between sites when the broadcast is made so that no site picks up the message. To compare the schemes outlined above we assume that each site requires to know the whereabouts of a global object Q times a second. We further assume that a fixed fraction r of these seekings of global objects results in the object being moved. This fraction r is substantially less than 1. These figures are assumed to be independent of N the number of sites in the distributed system. Of the above schemes the search method is definitely inferior to continuous updating. The computation required to update a directory may be equivalent to that required to determine if a global object is resident but not all requests for the location of an object result in the eventual moving of the object. Hence the continuous updating method involves fewer broadcasts, and does not involve the extra "X is at my site" message nor the enforced delay while the information is gathered; all for the cost of memory space to hold a directory at each site. In the distributed system we are proposing the number of global objects is likely to be of the order of 10 to 50 so the cost of holding a directory at each site is not great. evaluation of the other schemes requires consideration of the form of broadcasting. We have seen that for the bus and the DCS type loop a broadcast costs the same as a message in terms of the use made of the total bandwidth. Also the work done by the sender is identical for either. (The total work done by the receivers of a broadcast will always be N-1 times that for a message). For simple complete connected schemes a broadcast will use N-1 times the bandwidth that a message uses, and the sending site will probably have to do N-1 times the work. For either type of communication subsystem the total number of messages (related to global object management) received per second for the whole system will be N(N-1)Or when using continuous updating. When using a central directory scheme (N=1)Or update messages will be received by the directory site per second, (N-2)Q messages will be received by the directory site requesting the whereabouts of a global object and the same number of replies will be received at the non directory sites, making a total of O((N-1)r+2N-4) messages per second. Thus, considering only the minimization of work done receiving messages for a value of r = 1% (which turns out to be a high value, see in the sample outputs of appendix A the ratio of TRANSFERRED DUMAINS to TRANSFERRED PROCESSORS), the number of sites, N, would have to be greater than 203 for a central directory to perform than continuous updating. When a directly better connected communication subsystem is used, the number of transmissions is the same as the number of receptions. But for a communication subsystem where a broadcast costs the same as a message then the overall work done using continuous updating is less, so that N will have to be even larger before break-even point is reached. By the time we quantify the inconvenience of having to wait before a global object's location can be retrieved, it is obvious that a central directory is inferior continuous updating. We have already mentioned that an associative scheme is not appropriate for a system with a directly connected communication subsystem. So, for such a system, continuous updating of directories held at every site is the best scheme. In an associative scheme there are no management messages sent whereas, for a loop or bus, a continuous updating scheme gives NQr broadcasts per second resulting in N(N=1)Qr messages received. The fraction of total available processor power used in maintaining the updating is directly proportional to N. For either scheme the fraction of processing power used in actually shifting global objects is constant. Hence the associative scheme is preferable to continuous updating, at least when large scale sites are envisaged. The interface units required for an associative scheme may not be cost effective for a distributed system of very low powered computers. ### Status updating: We show later (in chapter 7) that there is a need for each site in a distributed system to have some information about the status of other sites. While the information each site requires about the others is not very much, it must be reasonably up to date. The ideal is that every site has completely accurate information about every other site, but finite communication bandwidth makes its achievement impossible. A distributed system can tolerate some misinformation, but the more inaccuracies there are the less efficient the system will become. Below we discuss four ways that sites can interchange information. 1) Broadcasts at regular intervals: This policy has the obvious disadvantage that the number of broadcasts will go up in direct proportion to the number of sites. Since every site will have to be interrupted to receive its message from every other site, the fraction of computing power in the distributed system - dedicated to updating this information will be directly proportional to the number of computers in the system. - 2) Exchanges between neighbours: To mitigate the interruptions caused by receiving broadcasts from every site, each site could be arbitrarily assigned several neighbours with whom they exchange tables of the supposed state of the whole system, similar to the way routing information is updated in the ARPA network [MCQU72]. The neighbour relationship would have to be intransitive so that information about every site in the system would work its way through to all other The items of information built up from exchanged tables will be of different vintages. There can be no guarantee that sites will confine their normal transactions to their neighbours; the frequency of exchange of information will have to be high if a good proportion of the information is hopelessly out of date. - 3) Appended to normal messages: Since the amount of information each site would want to propagate about its state is quite small, perhaps 2 bytes worth, it can be appended to normal messages between sites without increasing overheads significantly. Indeed in systems such as Ethernet [METC76] there is a fixed minimum length message and since many control messages could be shorter than this length, the information about the sender's site could be carried for free. The sending of messages is likely to be correlated with changes of state of the site, and hence with the need to update the information held at other sites. When two sites are interacting heavily they would have their information about each other updated frequently. When a site is idle and not interacting with other sites, its status would not be changing, so it would not interrupt other sites to give them information they already have. 4) Eavesdropping: In a system that appends state information to messages and has associative interface units, such as loop or bus systems, the interface units can take over the intelligence gathering function. Further they need not use messages addressed to just their site, but can pick the state information (and, of course, source) of all messages that pass on the loop or bus. The interface unit would maintain a status table so as not to interrupt the kernel too frequently. The kernel could consult the table when required. Compared with the first two methods, appending information to normal messages has the obvious advantages in the conservation of bandwidth and minimization of interruptions to sites. The differences between information gathered from all messages transmitted and from only the messages received at one site will be minor if broadcasts are a frequent occurance. Thus when a directory update scheme of global object management is being used (with its broadcasts of changed object location) the information contained in only the messages received at a site will probably be sufficient. However, there are few or no universally received because broadcasts, eavesdropping will probably be required in a system with a bus or loop type communication subsystem (that used an associative scheme for managing global There is nothing to stop a site performing a dummy broadcast when it felt its status had reached some point and this would help homogenize the information held at all the sites. the Whether or not extra hardware complexity of eavesdropping would justified requires investigation. In the simulation of a distributed system described subsequently we assume a completely connected system. Continuous updating is used to locate global objects and status information is appended to normal messages. This, we considered, would represent a practical implementation However we feel that any major at the present time. implementation in the future should involve construction of an Ethernet type of bus with associative and perhaps an eavesdropping recogniton of addresses mechanism to gather status information. Distributed control serial buses, like Ethernet, offer ultimately very high bandwidths using very cheap materials [ADAM76], the transmitting media (co-axial cables, twisted wire pairs or optical fibres) are passive giving immensely enhanced reliability compared to schemes involving a complex of electronics in the transmission. ### CHAPTER 4 #### OPERATING SYSTEMS ARCHITECTURE The designer of an operating system for a distributed system has two alternatives: he can attempt to 'distribute' some form of existing single site operating system architecture or he can invent something completely new. Lacking the required inspiration for the latter approach we have chosen the former. Consequently, to decide on an appropriate architecture for an operating system, in a distributed system we now look first at those for single or multiprocessor/shared memory systems. # SECTION 1: SINGLE SITE SYSTEMS ARCHITECTURE. Apart from manufacturer's monolithic monstrosities, operating systems can be classified into four types of architecture. The classification is made according to how users, resource allocators and other operating system services are permitted to interact. A goal of all architectures is to make interactions between functions 'clean'. Ideally each function does not have to make any assumptions about how other functions are realized. We emphasize before we describe the categories that they are not mutually exclusive. ### Hierarchical: Dijkstra is the initial proponent and publiciser of the strictly hierarchical architecture [DIJK68,DIJK71, PARN74a]. Each function of an operating system is statically assigned a unique level. The first level function is programmed to work on the bare hardware. The second level is programmed for a system consisting of hardware plus the first level. It should not have direct access to the resources controlled by the first rather it should invoke the primitives provided by the first level. Likewise the second level provides the environment in which the third level is programmed and so Each layer 'rebuilds' the machine into a more on. attractive machine. In Dijkstra's view an operating system should be regarded as a sequence of layers, built on top of each other and each of them implementing a given improvement [DIJK71]. Implementing a strictly hierarchical system requires a firm belief that functions can be totally ordered, a foreswearing of co-routine type interactions between functions, and skill in determining the correct ordering. Interactions between functions can be one way only. ### Virtual machines: Variants of the virtual machine architecture form the largest class of extant structured operating systems. Basically every user has his access to resources (including core and CPU time) controlled by a single virtual machine monitor or kernel (we prefer the later term). This kernel is entered, perhaps by instruction traps, every time the user wishes to acquire or release resources, and it ensures a 'fair' distribution of the resources. The user is encapsulated. He cannot communicate or interact with other users, he is to all intents and purposes using a private computer, a virtual machine. The pure virtual machine variant provides no more facilities to the user than the bare underlying hardware hardware of another machine) the [MEYE70, PARM72, BUZE73, GOLD73]. The user has to provide himself with an operating system to run in his virtual machine. This can lead to horrendous inefficiencies The kernel knows nothing of the behaviour of [GOLD74]. the operating systems in the virtual machines, nor are the operating systems aware that there is a kernel beneath them. The advantages claimed for this kind of virtual machine are that it provides absolute security because there is no interaction between virtual machines [POPE74] (which security has proved elusive [ATIA76]) and allows for the development of new versions of operating systems concurrently with the use of previous versions. In other virtual machine type operating systems such as EMAS [AHIT73] or MULTICS [CORB72], the kernel (called Supervisor in EMAS) provides a number of services, such as managing paging and dispatching, to enhance the bare The individual 'operating systems' (Directors machine. in the case of EMAS) are integrated with this kernel. not duplicate the provided facilities and they They do could not run on the bare machine. Tuning of integrated systems does not present the same dificulties as does pure virtual machine system. The tuning a his virtual principle of the user having access to machine, and nothing else, can be softened by kernels limited interaction with other virtual allow machines, usually via the filing or I/O subsystems. # Intercommunicating processes: Process orientated systems have received a lot of attention in the literature [KNOT74] and are exemplified by the RC4000 system of Brinch Hansen [HANS70]. kernel, the basic addition to the hardware, provides the primitives for process management, creation, deletion and intercommunication. The rest of the system is a set of processes. In particular, resources are identified with the processes that control them. Processes are capable of interacting with any other which process, is a considerable difference the virtual machine from This interaction is accomplished using situation. messages. The kernel provides primitives such as 'send', 'receive' and 'wait for answer' which buffer messages and suspend processes. The kernel normally implements an addressing scheme that gives processes unique names and allows messages to be addressed using these names. In some systems extra refinements are added, such as ports [BALZ71], so that a process does not even have to be aware of the name of the process with which it is communicating. Parallel execution of a program is catered for in a process orientated system. A subroutine call can be implemented as a message (containing the parameters) to a process, this process returning a message when it is finished. Thus systems often provide for the creation and destruction of processes and the placing of processes in a hierarchy of ownership (parenthood). This feature, although used by Brinch Hansen in RC4000, has recently been criticized by him as being very costly in runtime checking of the validity of process interactions [HANS74,HANS75]. He advocates that an operating system should consist of a fixed number of processes, at least for a given configuration with fixed resources. Hansen is also critical of messages passing systems because they create an artificial resource, message buffers [HANS73]. Message buffers require management; their allocation has to be carefully controlled if deadlock, through insufficient message buffers, is to be avoided. Transmission of messages involves copying messages into and out of buffers, which is highly wasteful of processing power, at least in single site systems. (One message passing architecture, that of the GEC 4080 [GECC75], has microprogrammed functions to help with message passing, making it more efficient). Lampson [LAMP71] feels that message systems are not convenient to the user; elaborate conventions, or contortions [SPIE73b], are required to find out the unique names of the operating system facilities the user requires. #### Kernel/domain architectures: Maintaining effective control in operating systems that permit general interactions has been likened to 'running a three ring circus, in one ring, in the dark' Capabilities are the basis of a mechanism [METC72a]. that allows general interactions to be controlled. Capabilities allow each computation access to all the resources it needs at a particular time. All resources are intrinsically shareable, but the computation is not permitted access to resources that, at its current stage, it does not require. Strictly speaking a computation has access to all resources, and only those, for which it possesses a capability [DENN66]; the assumption being made that the ownership of capabilities is so organised to reflect the current requirements of the computation. The set of resources that, at any time, a computation has access to is called a domain [LAMP71,NEED74], also sphere of protection [DENN66], parameter space [EVAN67], NCP [SP0071], local name space (LNS) [NULF74], protected subsystem [SALT74] and domain incarnation [SPIE73a]. Should a computation prove erroneous its effect is likely to be limited to the current set of resources. The resources are enclosed in a 'firewall' and incorrect operations are contained and do not affect the rest of the system. Capabilities normally restrict the type of access a computation has to its resources; for example a segment may be accessed as read/write, read only or execute. The basic function of a kernel in a capability system is twofold: - 1) It enforces, or assists the hardware (NEED74,ENGL74) to enforce, the restrictions on the type of access to resources, including null access to resources for which no capability exists. For example the kernel should detect and disallow a destroy operation on a file when the computation only has the capability to read from the file. - 2) The kernel assists computations to change the set of resources that they have access to (when this function is not carried out entirely by the hardware). We call this operation an interdomain jump. The kernel, in giving and removing access to resources, can control allocation of resources if it wishes. Process dispatching is usually included in the kernel also, either for operational efficiency or to ensure fairness in the allocation of processing capacity [WULF75b]. Resource management in capability systems is performed in two different manners. Either a computation is given direct access to a resource by being given a capability for the resource, or the computation is given just a capability for the execution of a piece of code that manages the resource. In the latter case, to execute the code, the computation changes its domain, or protection environment, and the resource becomes available to it. But the resource is available to the computation only for as long as it executes the appropriate code. In many capability systems the kernels provide the facilities by which a computation can create, delete, copy, contract the types of access, or expand the types of access [FERR74] of a capability. These facilities are appropriate when the type of dynamic creation and deletion of processes (and accompanying resources), mentioned above in relation to message passing systems, forms the underlying philosophy of the system. We have adopted the same attitude as Brinch Hansen and tried to do without such dynamic behaviour. There are unsolved problems in combining copying of capabilities with the ability to delete them [REDE74] and we think these problems would only be exacerbated in a network environment. One of our goals in designing a distributed system is that there should be as little as possible duplication of operating systems functions at different sites. We want the normal work of the system to be uniformly distributed across the system and, following the philosophy of Spooner [SPOO71] and others that the constituents of the operating system should not be specially privileged, we determined that the ideal is to have systems functions spread across the system as well. Another goal, derived from the queueing theory considerations expressed in chapter 2, is to have no site idle while there is work waiting to be performed at other sites. This implies that load levelling or balancing operations must occur frequently, and that the overhead of these operations is an important factor in the success of a distributed system. With these two goals in mind we now examine the four types of operating system architecture, outlined above, for their suitability for extension to distributed systems. ### Hierarchical: The hierarchical scheme is superficially the most attractive of the architectures to extend distributed system. The 'only' requirement is to provide a bottom layer that somehow melds the different machines in the systems into a 'more attractive' single machine upon which Dijkstra's or any other operating system can be placed. Goodwin [GOOD73] has tried to take this approach with his tree structured distributed system. The basic layer provides for communication between physical processors and a tree structured naming mechanism. On top of this was planned a process communication system; the bottom layer taking care of messages for processors that do not belong at the same site as the sender process. We have already criticized Goodwin's proposals because of the likelihood of half, or more, of the messages travelling through the root node. further criticism, stemming from adherence to hierarchical layering, is that there can be no migration of load from overworked sites to idle sites. The bottom layer has no concept of processor allocation, that belongs to higher levels. The higher levels do not know that the underlying machine is in fact a distributed system, for that is against the rules of the game. the assigning of processes to sites has to be outside the system and would have to be done every time the system was reconfigured. The difficulty with incremental layered machine improvements in a distributed system is that in order to load level and balance the use of resources, there has to be some two way interactions. Structuring systems into layers is a good technique but a practical system must have many interacting functions in each layer. # Virtual machines: It is pertinent to enquire, if one is adopting a strict virtual machine architecture, whether it is worth having a distributed system at all. The purpose of the virtual machine architecture is to create a set of private 'bare' machines. Unite possibly all the kernel for a distributed system would be doing is tying together a number of physical machines just so that it can simulate the same number of virtual machines. Thus if the division of virtual machines is fairly static, greater efficiency would be obtained by not integrating the physical machines together, dispensing with the virtual machine monitor, and putting the virtual machine operating systems onto the physical machines. When there is intended to be a multiplicity of virtual machines at each site in the distributed system then a distributed system could be justified by the possibility of load levelling. A kernel would reside at each site and manage all the virtual machines at that site, as it would in a single site system. But, somehow, a load levelling apparatus could be incorporated so that the kernels could co-operate in moving virtual machines (by copying their total memory space) away from busy sites to idle sites. Problems arise both at the level of determining opportune times to shift virtual machines and then of handling peripheral devices after a virtual machine has been shifted. The kernels would probably waste a lot of time time polling each other to see how busy they all were and would be likely to grow rather large to handle the intricacies of shared peripheral devices. Karoline [MADS72] was planned to have 8 virtual machines at each of 8 sites, but proposals for load levelling, if they were considered, were not published. For the less strict virtual machine architecture where kernel provides the virtual machine monitor or services, and sharing of files is permitted, there have been at least two implemented distributed systems, RSEXEC [THOM73,COSE75] and SBS [AKKO72,AKKO74,AKKO75]. what might be called the hypervisor take systems approach. Each site maintains a full operating system or supervisor and extra facilities are added, often at a user level, to form the hypervisor, integrating the site into the distributed system. So far these have just implemented network wide file facilities systems so that files (and peripherals) can be accessed by a user from any site in the distributed system. This feature has been exploited, at least in RSEXEC [COSE75], to attempt load balancing at 'log in' or job initiation time by directing users to the least utilized site. No mechanism has been developed for moving a job from site to site once its execution has begun. The advantage of these types of system is that they can be built on top of existing operating systems, or at least those that have been sympathetically designed [METC72b,ZELK74,RETZ75]. The disadvantages are the duplication of operating systems at each site and the inability to load level, except crudely as above, because these operating systems are really autonomous units. ### Intercommunicating processes: The Distributed Computer System (DCS) being developed by Farber and colleagues [FARB72a,b,c,d,FARB75,ROWE73], is the archetype of process orientated distributed systems [LAYM74]. We have already mentioned two features of the DCS system in chapter 3. It has integrated its hardware into the system design by employing an associative mechanism in its communication system for direct addressing of global objects. The global objects in this case are processes. Also DCS broadcasts are as efficient in the use of bandwidth as are single messages. kernel at each site is extended (from single site form) to place any interprocess messages that it cannot deliver at its own site onto the network communication loop. There they will be picked up by the appropriate kernel (because it has set the names of all resident processes in the associative memory of its interface unit) and eventually delivered to the correct process. The other major change in making a distributed system is resource allocation. Resources, we said, were identified with processes in process orientated systems. The management of these resource controlling processes can be carried out by allocator processes. DCS has one allocator per site (though not necessarily residing at that site). The interaction between users and allocators is modelled on microeconomic theory and is the basis of load balancing in DCS. when a user requires a service, the execution of a particular type of process (such as a text editor), which will use resources (memory and perhaps peripherals), he (his agent process) sends a message to all allocators requesting a 'bid' for the provision of the service required. The allocators all answer to a common name so that only one message on the communication loop is required to ask for bids. Allocators return bids and after a fixed period of time the user evaluates the bids he has received and chooses the allocator with the smallest bid. He sends this allocator a 'contract' message. The allocator can then create a process of the required type at its site and return the process name to the user. But bids are not binding and so an allocator could have allocated elsewhere some of its resources in the time taken to evaluate bids, in which case the 'contract' is spurned and the user has to start requesting bids all over again. Thus DCS load balances basically at a job-step or complete command level. From the above description, for an N site system, 1+(N-1)+2 messages on the communication loop are required for a first time successful allocation of a process to a user (when the allocated process is at a different site from the user's agent process). Thus it would seem that the overhead would be too great for attempting finer load balancing. There are other process orientated distributed systems under development, DCN [LAYM74, MILL76] is one, POGUS [DUVA75] is another. But, as far as we are aware, a load balancing or load levelling strategy has not DCS, and there has published for any but been no published evaluation of the operation of DCS. been told however that for POGOS, a network of 16 or more identical minicomputers, attempts at load levelling produced instability and were abandoned. Processes were being transferred around the system too fast to useful work between moves. Unfortunately, no details have been published. A very recent paper [MILL76] states that load levelling mechanisms are still to be developed for DCN. Finally one other feature of DCN, POGOS and DCS is the duplication of non-kernel code at all sites. In DCN all functions, that is the code for the processes that reside at each site. functions, implement these Migration of a function involves shifting only the of the process to a new site [LAYM74]. memory space has been permanently traded for decreased traffic on the communication loop. In POGOS a copy of the whole POGOS operating system, which admittedly quite small and primitive, resides at each site. DCS does have duplication for fail-soft reasons but it required also because any site, if underloaded, has to be able to create (almost) any process. # Kernel/domain architectures: The functions of a kernel in a single site domain system are to multiplex ready-to-run computations on the physical processor and to handle the interdomain jumps. We emphasize again that when a computation has entered a domain it accesses resources within the domain and no others. Thus in a distributed system a process will be able to execute unimpeded when all the components of a domain are at one site. If there is a kernel at each site and it provides a distributed interdomain jump which ensures all the components are at one site, the rest of a single site domain system can run with no alterations, just as an interprocess communication system can run once the communication primitives have been extended. The distributed interdomain jump is the key to the operation of a distributed kernel/domain system. process wishing to change domains notifies its local (that is the kernel at the site where it was executing in the domain it now wishes to leave). kernel has to locate the new domain (domains are the global objects in this system) and in co-operation with kernels, choose a site at which the process is to other enter the new domain. The kernels then have co-operate, by sending messages to each other, in shifting the domain components to that site, if any need When all the components of the domain are at shifting. the chosen site the kernel there schedules the process for execution again. The distributed interdomain jump allows load balancing, as distinct from load levelling, to be performed at quite a fine level. Work is not arbitrarily moved around to level the load at each site, but each request to enter a domain is taken as an opportunity to shift the components of the domain to another site if the current status of all the sites indicates that this is desirable. Every time interdomain jump occurs there is an opportunity for the system to move towards balanced loading. The occasion of an interdomain jump is also optimum with respect to the volume of data that has to be moved if the computation changes site. At most, all components of the new domain will have to change site; frequently some of the components will already be at the new site. The choice of new site can be made to minimize traffic on the communication subsystem. ### Synopsis: In this chapter we have examined various types of operating system architecture and their suitability for extension to distributed systems. We have shown that a strict one function per level hierarchical system is not suitable because load balancing cannot take place. Those systems that have kernels at the lowest level implement several co-operating functions, can be more extended to distributed systems. The readily inefficiencies of strict virtual machine architectures seem likely to be increased but, logically at least, both process orientated systems and domain systems suitable for extension to distributed systems. We have indicated areas that are considered by some to be drawbacks of process intercommunication systems per se, and we have stated what we consider to be the drawbacks of process intercommunication systems as a basis for distributed systems. A change in emphasis away from processors towards domains, away from managing messages towards managing environments, provides, we feel, the key to a successful distributed system. A distributed operating system based on the kernel/domain architecture offers great potential both for minimizing the duplication of code and for fine grain load balancing. The rest of this thesis describes more thoroughly the kernel/domain architecture, outlines strategies and mechanisms that could be employed in implementing the distributed interdomain jump, develops some of these mechanisms, describes a simulation program that 'exercised' these mechanisms and analyses the results of this simulation. ### CHAPTER 5 # THE DEVELOPMENT OF THE DOMAIN CONCEPT Introduction and terminology: This chapter presents a survey of the development of the domain concept. We show the connection between segments and capabilities and show how capabilities are used to define domains. Our intention is to demonstrate that domains can be considered to be the predominant structure in a computer system. The concept of a segment dates back at least to the Burroughs 85000 [BURR61]. A segment's attributes are some form of identification or name, and a length or total number of data objects (normally computer words, bytes or instructions). Elements of a segment are accessed by identifying the segment and specifying an offset within the segment. It is assumed that the segment's elements are stored contiguously or, as in a paged system, discontinuities are taken care of subsidiary addressing mechanisms. If ambiguity addressing is to be avoided a segment needs a name unique to all the possible environments in which it will be If addressing is to be controlled, as in a protection scheme, then the generation of segment names has to be controlled. Both the method of naming segments and the mapping of segment names into hardware segment starting addresses have been the subject of a great deal of study. Dennis and Van Horn [DENN66] are generally credited with being the pioneers of protection schemes and being the first to use the term 'capability'. A capability is essentially a name, or a pointer; a computation that possesses a capability can access the item named. Capabilities can name general objects or resources [LAMP71]. The capability concept has been formalized by recent writers [NULF74,FERR74,LAMP76] so that a capability consists of three items: - a type denoting the class of object named (of which segment is one such class) - 2) a value being the name or identification of the object - 3) a set of rights indicating how the named objects may be manipulated by the holder of the capability (the available set of rights will depend on the type of the object). We discuss later how resources can be associated with segments so we restrict our interest initially to capabilities for segments only (PARN74b) (and later to entry capabilities which are capabilities for special groups of segments). The type of access permitted to a segment is not really germane to the development of the domain concept. Hence we will consider a capability to be synonymous with the name of a segment or a pointer to a segment. So, in tracing the development of the concept of a domain, we concentrate mainly on models of computer operation where the only resources in a domain are segments. We are interested in the segments accessible to a computation as the computation proceeds. Of particular importance is the sharing of segments between different domains or environments. When it is desired to shift a computation from one site in a distributed system to another then all the segments currently accessible to the computation (i.e. its domain) have to be collected together at the new site. This operation will be considerably complicated if some of the segments are simultaneously accessible to other computations. Before we go on to examine various models we attempt to clarify some of our terminology. The term 'process' in Computer Science has collected many different shades of meaning. Spier [SPIE73a] makes a cogent case for using the term 'virtual processor' to denote the idea of execution of a user's sequential computation. A virtual processor is in a one to one relationship with a user, and the user's computation proceeds only when a physical processor is allocated to the virtual processor. A virtual processor executes (potentially) all the code that defines a user's computation but neither code nor state space [DIJK71] define a virtual processor. The virtual processor is an agent acting on behalf of the user. It is the pseudo-processor of Saltzer [SAL[66]. In the following sections we have altered the notation of the original descriptions when these used the term 'process' to mean no more than virtual processor as we have defined it above. We have retained the term 'process' however when there are other connotations; for example when a segment of code defines a process and a subroutine call implies a change of process, or when user level parallelism permits a user to 'own' many processes at once, or when resources are managed by processes. # The Evans and LeClerc model: Although Evans and LeClerc [EVAN67] did not use the term 'capability' (using the term 'parameter' instead), they seem to be the first to describe a computation as progressing through different (protection) environments, in each of which the computation possesses different capabilities. They concerned themselves solely with segments and they made a procedure activation, or deactivation, the occasion of altering the environment. When a computation enters a new procedure some (at least) of the segments it accesses will be different. In particular, if we identify each procedure with a separate code segment, then the code segment from which instructions are fetched will be different. Evans and LeClerc recognised the importance of the code segment in delimiting an environment and called the code segment the 'root' segment of an environment (which they called a parameter space). An environment is defined by an ordered list of capabilities for segments, this list being called a c=list by most writers [DENN66,LAMP71,WULF74,COHE75]. The first capability in the list is for the code segment. The segments referred to by the the other capabilities are of three sorts:= fixed: the segment does not change with each entry into the environment dummy: a different segment can be used every time the procedure is entered (the conventional parameter) scratch: the system will supply a fresh temporary segment for every procedure activation and will reclaim the segment when a return is made from the procedure. Any of these other segments may be root segments of other environments, leading to a nested structure of environments as depicted in figure 5.1. Any segment may be in many environments simultaneously. A user formulates addresses by specifying the number in the c-list of the capability for the segment, plus the offset within the segment. Thus programs do not have to worry about segment names or hardware addresses and are not allowed to use them directly. Addresses are taken relative to the current protection environment as defined An environment hierarchy of Evans and LeClerc. Figure 5.1 by the c-list. Evans and LeClerc also present mechanisms for addressing items that are in subsidiary environments, so that the whole system structure is not unlike that under a 'rings of protection' regime [GRAH68,SCHR72]. Procedures high up the hierarchy can access everthing lower down. A procedure call or subroutine call is implemented simply enough, as the address it is desired to transfer to can, and must, be generated in the calling environment. That is, all subroutines that can be called directly from an environment have their code segments as part of that environment. The transmission of arguments is envisaged to be of three kinds: Entire segments: The calling routine presents the system (kernel or hardware) with a list of segment capability numbers indicating what positions they should occupy in the c-list of the called subroutine. The system makes copies of these capabilities in the new c-list. Portion of a segment: The calling routine gets the system to create a capability for part of a segment and this is placed in the new c-list. Individual values: The values of simple variables have to be stored in a stack segment and the capability for this segment passed to the called subroutine. Unfortunately, procedure or subroutine returns cannot be handled using just an index into the current c-list, because the code segment from which the call originated is not likely to be part of the called environment and therefore there is no way for a transfer instruction to formulate the return address. This is where the unique names of the segments should come into operation. Evans and LeClerc use a variation in that they give system wide unique names to every environment. Hence a return link consists of the unique name of the calling environment, which is the same name as the root segment, plus, of course, an offset for that segment. They have then to introduce a protected stack segment attached to each virtual processor to store links. The application of unique names to environments rather than segments does not appear to be a felicitous choice. By considering every non-root segment in an environment to be a potential root segment of another environment, as Evans and LeClerc do, all segments can be given at least one unique name. Confusion will arise however when the same root segment is part of two different environments. Evans and LeClerc would have been better advised to recognise that a c-list defining an environment can be stored as a segment, and give unique names directly to each segment including the c-list segment. Spooner [SP0071] also proposes a segment based model and he seems to the first of use the actual term 'kernel' and define in detail the functions of the kernel. He again attaches great importance to code segments. A code segment defines an operation to be performed by the CPU on an operand area. The same (compound) operation can be performed on different operand areas corresponding to different, but possibly concurrent, activations of the procedure defined by the code segment. Spooner uses the term 'operand area' as he envisages 'windows over core' [SP1E73a], that is segments are permitted to overlap so that the same data item may belong to many segments. However a change of procedure is held to be a possible change of environment and is managed by the kernel. Spooner introduces a third type of memory area, an activity base. The activity base, as well as providing space for dumping working registers when the virtual processor is suspended, records 'permitted connections', that is capabilities for combinations of code and operand areas (see figure 5.2). These are the forerunners of entry capabilities (NEED72). Spooner rightly recognises that access rights, or capabilities, should be a function both of the virtual processor and the code it is executing. The possibility exists for a virtual processor to acquire totally new rights when entering a routine, in comparison with the scheme of Evans and Spooner's model showing 2 possible 'permitted connections' Figure 5.2 LeClerc where the capabilities are confined to the hierarchy of segments of which the routine is part (figure 5.1). Spooner also makes the use of protected entry points or gates mandatory. Earlier work described protected entry points for code, the restriction of jumps into the code from other procedures to a number of fixed locations, but the use of them was not thought to be necessary all the time. But without protected entry points no guarantees can be made about the operation of a code segment. # The Spier model: Spier, working from the ideas of Spooner, and Evans and LeClerc, developed a model for quite a comprehensive protection system [SPEI73a] and also implemented a restricted verson of it [SPEI74]. The following discussion relates primarily to the implemented version, while adopting some of the terminology of the former paper. Spier identifies five different kinds of memory area (segment). These are: - 1) A body of a pure remember procedure. This segment is potentially shareable by all virtual processors. It is called the procedure segment. - 2) A protected data base whose information is managed by an associated procedure. Again the single physical copy of this segment is shared by (all) virtual processors. It is called the domain own segment. - 3) A working storage area for permanent local values, values preserved from one procedure invocation to the next. These segments are unshareable so that there is one for every procedure that has been executed by each virtual processor. These segments are called incarnation own permanent segments. - 4) A temporary segment which contains a virtual processor's execution stack and other temporary variables for the invocation of a procedure. Again not shareable, this segment is called the incarnation own temporary segment. - 5) A communication area for transferring parameters between procedures. There is one per virtual processor which is accessible by that virtual processor no matter what procedure it is executing. This segment is called the argument segment. In the above the importance of a procedure as defining an environment is again seen. A procedure segment, together with its domain own segment, forms the basis of a domain, a 'firewalled' group of segments. A total domain consists of the procedure segment, the domain own segment and all the incarnation own segments (both permanent and temporary) related to the procedure segment. None of these segments belongs to more that one domain. The argument segment is associated with a virtual processor and is carried along with it as the virtual processor progresses from domain to domain. Thus each argument segment is shared, serially, between domains. Figure 5.3 shows the relationships of segments to two domains and two virtual processors. A virtual processor always enters a domain by a kernel controlled interdomain jump to a protected entry point, or return point. The set of segments that the virtual processor may access while in the domain is called the domain incarnation for that virtual processor. There are five segments that the virtual processor may access: the procedure segment and the data base or domain own segment of the domain, the two incarnation own segments that relate to both the virtual processor and the domain, These five segments form the the argument segment. environment of the virtual processor. Until the virtual processor invokes the kernel to change domains it cannot access any other segments. After such a change, cannot access any of the segments of the original domain incarnation save for the argument segment. For each virtual processor the kernel maintains an activation area, containing chiefly information about the domain incarnations that the virtual processor is | | | Domain A procedure and domain own shared by virtual processors 1 & 2 | | | |----------|----------------------------------------------|----------------------------------------------------------------------|---------------------------------|----------------------------------------------| | Domain A | Argument segment 1 shared by domains A and B | Incarnation A1 own permanent | Incarnation A2 own permanent | Argument segment 2 shared by domains A and B | | | | Incarnation A1 own temporary | Incarnation A2<br>own temporary | | | Domain B | | Incarnation B1 own permanent | Incarnation B2<br>own permanent | | | | | Incarnation B1<br>own temporary | Incarnation B2<br>own temporary | | | | | Domain B procedure and domain own shared by virtual processors 1 & 2 | | | # Segment access in Spier's model Figure 5.3 permitted to access. This is, in effect, in the form of sets of four capabilities, for the four segments that together with the argument segment constitute each domain incarnation. A current domain pointer indicates the set of capabilities that define the domain incarnation the virtual processor is currently in. The kernel also maintains a hidden stack so that interdomain procedure returns can be controlled. The kernel's action for an interdomain transfer consists essentially of correct handling of the stack and repositioning of the current domain pointer so that the correct environment will be invoked when processing proceeds. Spier [SPIE74] describes briefly a mechanism whereby a virtual processor's activation area need not contain, at virtual processor initiation time, all the incarnation capabilities it will need as a computation proceeds. This involves domains having unique names within the system and being objects in the filing system. When a call to the kernel requests entry to a domain that has not been entered before, the domain procedure and data base segments are copied into active storage (i.e. given hardware addresses). The first time a particular virtual processor requests entry to the domain the incarnation own segments are created in active storage as set of capabilities for the domain the incarnation being placed in the virtual processor's activation area. No description of the reverse processes unloading domains from active storage and removing o f capabilities from a virtual processor's activation area is given. The weakest details of Spier's implementation are a consequence of his having just five segments (one of each kind) per domain incarnation. Firstly, the possibility is denied of segment structure reflecting any underlying divisions of the procedure's variables (other than the permanent/temporary division). Secondly, parameter transmission can become very inefficient. When a few simple items are the only arguments that pass between domains then the overhead of copying these into the argument segment and copying them back again is not too great. But, as Spier's model stands, the accessing of a whole segment's worth of data from more than one domain can be done in one of only three fashions, all unsatisfactory. - The data can be made a permanent part of the argument segment thus voiding any claim of confining data to the environments in which it is used. - 2) The data can be copied in and out of the argument segment as required. - 3) An entry point of the calling procedure can be made available to be used by the called procedure to access items of data as they are required (cf Algol 'thunks'). This involves a domain call/return sequence for every item of data [SPEI73a]. The Cosserat model: Cosserat [CUSS74] proposes a process orientated system where the number of segments accessible to a process is model is based on an actual hardware His varied. 250 the Plessey o f that architecture, [CUSS72,ENGL72,ENGL74]. Cosserat, following [FABR74], makes capabilities into data objects which can normal segments by be copied and overwritten in programs. Cosserat identifies three types of segment: - 1) Procedure segments: Cosserat allows his procedure segments to be impure so that they can store items and/or capabilities for other segments. Cosserat's procedure segment subsumes the procedure segment and the data base or domain own The capability for a procedure segment of Spier. segment is a type of entry capability. Outwith the procedure the only form of access to the segment transfer of control to the procedure. procedure is being executed then other forms of access are permitted so that data within the segment can read and written. - 2) Data segments: These contain general bit patterns and, as mentioned before, can also contain other capabilities (which the hardware always recognises as such). The capabilities for these segments are freely copiable so that the same segment may belong to more than one protection environment simultaneously. When a segment is destroyed some (unspecified) procedure has to be carried out to alter all capabilities for that segment to 'null' capabilities. 3) Process base segments: When a process is created (see later) it owns one segment, a special process base segment. This segment contains the capability for the procedure being executed and can contain parameters passed to the procedure. The segment also contains a dump area for temporary storage of working registers by the system and a return link to the calling procedure (see later). The capability for this segment is not explicitly available to the process. It is available to the creating process (with access rights such that the creating process can block and unblock the process but cannot access its data) and it is used by the system in its scheduler table entries. In Cosserat's model transfers of control to new procedure segments result in the execution of new processes. A GOTO type instruction results in the kernel/hardware placing the capability for the new procedure segment (which the old process must have possessed in order to formulate the address correctly) in a new process base segment and then deleting the old process base segment. Thus processes are truly identified with code sequences. A CALL type transfer results in the creation of a new process base segment but, this time, the old process base is not de-allocated rather the capability for it, suitably protected, is placed in the new process base. Hence a RETURN instruction can formulate the correct address to which control should be transferred. The newly entered procedure is not allowed to access the calling procedure's process base in any other fashion however. The creation of parallel processes is accomplished using a transfer instruction, but not de-allocating the process base of the creator and not removing it from the the scheduler. All these forms of transfer of control permit the transfer of parameters. The same convention is used in all cases: a list of data objects (which could include capabilities) in the current process base segment is specified by the appropriate instruction, and these are copied into the target process base. Since a process executing in one procedure segment does not have access directly to other procedure segments or to earlier process bases the only information that can be shared between procedures is that which is pointed to by capabilities embedded in the procedure at compile time, or that which is passed as parameters during a transfer of control. Cosserat effects the analogue of Spier's incarnation own segments by a modification of the transfer of control mechanism. He allows an 'indirect' transfer, a transfer to a segment which contains a number of capabilities. One of these capabilites is for the procedure segment, and the rest, which are made accessible to the processes executing the procedure, are capabilities for data segments. If each user accesses the code segment through different 'indirect' segments then the effect of incarnation own segments is achieved. Thus the following description of general resource handling could be applied to Spier's model if his concept of domain own segment were to be replaced by both domain own segment and domain own resource. All resources require code to manipulate them and if this code is gathered into a procedure segment then access to the code is equivalent to access to the resource. This is the representation of resources as segments mentioned earlier. Some resources, semaphores, can be represented in core so that data space associated with the code is all that is required to make the code segment a resource manager. Other resources, such as line printers, require special I/O instructions to manipulate them and the use of these instructions has to be confined to the code segment that manages the When the control registers for the device are resource. treated by the hardware as memory locations (as in the PDP 11 series and the Plessey 250) then this confinement achieved using the capability mechanism bе unmodified. For many types of resource a data area for each user of the resource has to be kept. This area could contain buffer space and/or status information such as, in the case of a filehandler, the names of the files currently opened by the user. Management of this information is facilitated by keeping it in separate segments, separate both from the common data and from the information related to other users. This is the function that the 'indirect' entry segments serve. This method of resource management has been successfully used on the Plessey 250. ### Other Protection Schemes: We have not dealt with all the protection schemes that have been proposed, concentrating on those that emphasise the code segment as the basic unit. Our chief omissions are CAP and HYDRA, both of which are being implemented, and the Chicago Magic Number Computer, CAL and SUE, the implementations of which were terminated prematurely. CAP is a machine with special capability manipulation hardware being developed at Cambridge LNEED72, NEED741. The main objects in the system are segments and processes and it is similar in many ways to the model of Cosserat. However the concept of a domain own segment, in Spier's terminology, that is a shareable data base, does not exist. Further the system is formulated in the context of a hierarchy of processes and the accessing of all capabilities through indirection tables to a master capability segment. A master process in the process hierarchy can treat its slave processes' capabilities as simple data. This produces reliability compared with single level capability systems [LAMP74] but we feel it is too general a mechanism to be incorporated in a distributed system. The Chicago Magic Number Computer [FABR74] was the first attempt at incorporating capabilities into a hardware architecture. Capabilities were for a single type namely those for segments. The resulting machine would, it seems, have been similar to the Plessey 250 but less efficient in its handling of alterations to capabilities when segments change location. The HYDRA system [WULF74, WULF75b, LEVI75, COHE75] is being mounted on the multiprocessor C.mmp machine. It allows an unlimited set of types of capability. Every object in the system, not just processes or domains, has an associated c-list so that arbitrarily complex objects can be built up. HYDRA is also process orientated allowing for the dynamic creation of processes. One type of object in HYDRA is the procedure. Entering a procedure involves the creation of a new protection environment. CAL [LAMP76] was an attempt to put a capability based system on a Control Data 6400 computer. It again had a multiplicity of types of object but c-lists belonged only to domains, and it would appear that the number of virtual processors in the system was fixed. The domains in this system were rather static objects compared with the equivalent in HYDRA. Domains existed for long periods of time so that a change of procedure involves a change of domain rather than the creation of a new domain. Project SUE was to result in a capability based operating system for an IBM 360 computer [SEVC72, SEVC74]. Again the system had many types of objects, capabilities for them, and it was also organized to support hierarchical processes. Processes were created with an environment that basically did not change. All resources were handed out along the arcs of the process creation tree. Capabilities for the resources considerably extended from the three field sort described earlier, to contain five fields including a count field. In SUE a capability not only gave access to a resource or object but specified how many times or how much of it would be accessed. It is interesting to note that the nucleus of an operating system for SUE was provided with about 10 processes, that is 10 protection environments, together with the kernel. The use of a code segment, containing a procedure or group of related procedures, to define a protection environment or domain, pervades almost all the models we have mentioned. The remaining contents of the domain vary from model to model but the idea of global data, all virtual processors that enter accessible to domain, and local data that is different for processor entering the domain, is common to The models also differ in the latitude given to models. segments to belong to more than one environment simultaneously, or even sequentially. As we implied at the beginning of this chapter, in a distributed less sharing there is of segments the easier the management of domains is likely to be. The entering of a new procedure is usually the occasion of changing a virtual processor's protection environment. Details of this change of domain vary from model to model, particularly in regard to parameters passed to the new environment. We have indicated that some movement of segments as parameters to new domains is essential if gross inefficiencies are to be avoided. This, of course, conflicts with our desire to have no sharing of segments between domains. The fact that the domain is the key concept in all the proposals and systems we have mentioned in this chapter, supports our assertion that the domain can be considered paramount structure in computer systems. with the successful implementations of capability based being so thin on the ground the kernel/domain systems architecture could hardly be called an established believe it to be a viable But wе technology. architecture and in the next chapter we propose a kernel/domain architecture suited to distributed systems. kernel/domain architecture is Our enthusiasm for the tempered, we admit, by one consideration. The size of domains is a question of vital importance to us, and one on which there has been no published information. CAP and the Plessey 250 use hardware to effect the interdomain jump so that the overheads of using domains, with frequent domain changes, are small. HYDRA has a software scheme to handle interdomain jumps and so domains, as a distributed largish requires probably will, to avoid the interdomain jump overheads swamping the useful computation. As yet there has been no indication as to whether the HYDRA implementors succeeded in generating large domains. We return to this question in chapter 7 when we look at how programming language structures relate to domains. # CHAPTER 6 OUR MODEL In this chapter we propose a kernel/domain architecture suited to a distributed system. First we give a brief discription of its structure and then give a detailed description of how the model could be implemented using capabilities. Finally we relate our model to those discussed in the previous chapter. SECTION 1: THE BASIC COMPONENTS. The purpose of all the models we have looked at in the previous chapter has been to enhance systems reliability, both by enforcing the run time protection rules of the model and, as Spooner and Spier stress, by the modular structure of software resulting from the design of domains or protection environments. While we do not want to dispense with these aids, our chief reason for wanting a computation divided into a sequence of incarnations of different domains is to allow the computation to be performed at different sites in a distributed system when, for resource utilization reasons, this is desirable. Much of the thrust of recent research on capabilities and domains has been to generalize their properties to every conceivable type of computational cover requirement. By analogy with the full flexibility of the Von Neuman architecture often being restricted (without real loss of function) in order to achieve efficiency [BURR61, FEUS73, DORA75], we have sought a minimal set of capability and domain properties that can be realized efficiently in a distributed system and at the same time cover normal computational requirements. Because Spier's model had the highly desirable property, for us, that no segment ever belongs to more than one domain at once, it made a good starting point for the model we have developed to meet the requirements for distributed systems. We give a concise description of the model before expanding on its features and giving justification for them. The basic components of the model are: - A reference space of segments, spread over and interchangeable between a number of sites. - 2) A number of virtual processors; relationships or associations, alterable in time, exist between virtual processors and segments (and also between segments themselves). - 3) A kernel, a software extension of the basic machine, exists at each site and manages virtual processors and segments. Kernels communicate with one another to effect this management. All transfers of segments between sites are performed by kernels. A segment that contains pure rementrant code is called a code segment and is potentially executable by all virtual processors. A code segment forms the basis of a domain, together with an associated public (data) segment, if one exists. A public segment consists of data that is usable by all virtual processors, but only when they are executing the related code segment. Local segments constitute the rest of a domain. There are local segments associated with every virtual processor that executes (the code) in the domain. They hold data relevant only to the associated virtual processor. A domain, then, is a group of segments which cannot be accessed by any virtual processor not executing the code segment of the domain. The entry to and exit from domains by virtual processors is carefully controlled by kernels. At the time of virtual processor entry or exit, local segments related to the virtual processor (parameters) may be transferred between domains. For each virtual processor there exists an associated segment, the processor base segment, which is accessible to only that virtual processor. It is accessible at all times, no matter which domain the virtual processor is executing in. This processor base segment, the code segment and the public segment of the domain the virtual processor is in, and the related local segments together form a domain incarnation (see figure 6.1). It is a sufficient condition for a virtual processor to proceed, on entering a domain, if all the components of the domain incarnation are at the same site. A domain that does not have a public segment is called a pure (code) domain. A domain incarnation of a pure domain may include a copy of the associated code segment rather than the code segment itself. A domain that does have a public segment is called a monitor (see later). # The Entry Capability: Capabilities are the normal mechanism used to implement domains. Cosserat's model assumes a tagged architecture [FEUS73] and allows capabilities segments to reside in normal data segments. However, the implementation from which his model was derived, on the non-tagged architecture of the Plessey 250, insists that capabilities reside in separate segments from data so that appropriate protection of capabilities be applied [ENGL74]. Either approach means that at a change of domain the identity of all the segments that belong to the new environment is not immediately obvious. capabilities are kept in separate segments a scanning operation is required to determine all segments in the environment. For Cosserat's model the problem is | CODE SEG. | |---------------------| | | | PUBLIC SEG. | | | | LOCAL SEG. 1 | | | | | | <del></del> | | | | LOCAL SEG. n | | | | PROCESSOR BASE SEG. | | | # A DOMAIN INCARNATION Figure 6.1 an order of magnitude worse; every segment must be systematically searched to make sure that no possible branch in the tree structured environment is overlooked. Only if we did not require to know what segments constitute the new environment at the time of a domain change could we use Cosserat's scheme (if we had a tagged architecture) or allow some local segments to contain capabilities only. But since, as we will explain, it is necessary to know what segments constitute a new domain incarnation, we have to forego the not inconsiderable advantages of list structured addressing [FABR74]. necessity arises in a distributed system because space has to be allocated for segments of a domain incarnation that are not at the site chosen for the domain incarnation, and these segments have to be brought to that site. This can be done at the time of domain entry (pre-loading) or the first time a capability is used in the new domain (demand loading). In paging systems pre-loading pages from backing store has been shown to involve less overheads than demand paging [ADAM75]. we show later, fetching a segment from another site is likely to involve almost as much work as fetching a group of segments together so that a similar trait with respect to segments is likely in distributed Accordingly in our model the capabilities for all the segments that will be involved in a new incarnation are placed in a single list, so that they can be quickly scanned to determine the requirements for the new environment. This list of capabilities for the segments making up a domain incarnation is called an entry capability. We have found the entry capability to be a very useful concept. The interdomain jump can be thought of as a validation of the entry capability for a new domain As its last action in the old domain a incarnation. processor places the capabilities for the segments of the new domain incarnation into a list (details about how this is done are given later on). call this list a c-list. The virtual processor calls the passing it the colist it has local kernel The kernel scans all the capabilities on constructed. the new c-list and if they all refer to segments resident at that site it (normally) will mark the c-list as a valid entry capability and place it in a queue of ready to run domain incarnations. If all the segments are not resident at the site then the colist is sent to the kernel where the code segment resides. This calculates what it considers to be the 'best' site for the domain incarntion to take place at, and passes c-list, suitably marked, to this site. The kernel at the 'best' site could decide that it did not want the incarnation at its site in which case it passes on the c-list to another site, but generally it will accept the c-list, go through it, and request kernels that have segments in the c-list to send those segments to its site. When all the segments have arrived at its site the kernel marks the c-list as a valid entry capability and schedules the domain incarnation for execution (see figure 6.2). The above is a very skimpy description, but it does show the importance of the entry capability in defining the domain incarnation in a compact form. The interdomain jump involves up to three scans, at different sites, of all capabilities for the domain incarnation. This shows the infeasibility of having a more general distribution of segment capabilities if preloading of segments is to take place. Before we give details on how segment capabilities are initially placed in calists we discuss the differences between the management of capabilities for code and public segments, processor base segments and local segments. #### Local segments: We mentioned that where capabilities were freely copiable the deletion, or even change of address, of a segment required that all copies of the capability be altered. In practice, in single site systems, all such capabilities are pointers to a master table [NEED74, ENGL74] so that all that is required is the alteration of the master entry to reflect the new situation, coupled perhaps with a usage count so that the master entry can be dispensed with when no capabilities point to it. In distributed systems we are, of course, # STAGE 1 AT LOCAL SITE Send entry capability to code segment site. # STAGE 2 AT CODE SITE Perform 'best' site calculation and send entry capability there. # STAGE 3 AT 'BEST' SITE Request other kernels to send component segments and then schedule for execution. BASIC ACTIONS PERFORMED FOR AN INTERDOMAIN JUMP denied the luxury of a central master table of capabilities. For local segments a master table could be kept in each processor base segment but this would complicate any interprocess communication involving the passing of segments. Hence we make capabilities for all local segments 'transfer only' [GRAH72]. This is a step better than Spier's completely static, no transfer, scheme for his incarnation segments. Only one capability for each local segment exists and this is passed from environment to environment as required. The only time a local segment is shifted between sites is at the time of domain incarnation entry. This is when the kernels have the entry capability list and so can easily modify the information in the relevant capability. A entry capability may sometimes hold pseudo capabilities instead of capabilities for local segments. These are of the following types: Transient: This pseudo capability just specifies a length so that the system can create a scratch segment for an incarnation at the site chosen for the incarnation to take place. When the segment is created a genuine capability replaces the transient one. Null: To facilitate the transmission of parameters between domain incarnations a slot in an entry capability may be empty. On disk: The segment is in a disk buffer. Descriptor: Used when a segment is not intended to be accessed by the current domain but to be passed on to another domain. The last two types have been introduced for reasons of operational efficiency and will not be mentioned again in this chapter. #### Code and public segments: Domains, as we have already stated, can be identified with their code and public segments. Entering a domain implies execution of the code in the code segment. Logically many virtual processors can be executing in a domain simultaneously (although, when there is one physical processor per site and only one copy of the code, only one virtual processor can be progressing through the code). Thus the code and public segments can form part of many different environments at the same time. We cannot make rules which would restrict these segments to single domain incarnations and not, at the same time, so emasculate the distributed system as to make it useless. Therefore to handle code and public segments a distributed equivalent for a master table of capabilities is required. We make the code and public segments of domains global objects (as discussed in chapter 3), the only ones in our system. We assume that at any time the kernels in a system can between them locate the code and public segment of a domain. Chapter 3 detailed how this might be done. This means that domains must have system wide unique names and every program must be appraised of the names of the domains it wishes (is permitted) to enter. Thus a capability for code and public segments is simply a name, it does not have any address information. The kernels have to translate this name into an address. # Processor Base Segment: The management of the processor base segment is the easiest of the three types of segment. Its capability need never be made explicitly available to a user, nor does it make sense for a processor base segment to be simultaneously part of more than one environment. When a kernel is requested to perform an interdomain jump it can take the processor base segment from the entry capability of the requesting domain incarnation and place it in the new entry capability. The kernel may have to modify the processor base segment itself to fix up return links. Spier's model uses the argument segment simply for carrying parameters between domain incarnations. Information about virtual processors is held in a special area in the kernel. Cosserat holds this information in his process base segment. This is the solution we prefer as then the information moves from site to site as the virtual processor moves from site to site. The processor base segment in our model is thus slightly anomalous in construction, consisting of quite separate sub-segments. These sub-segments contain: - simple variable values being passed as interdomain parameters - 2) entry capabilities for the domains that the virtual processor has entered - 3) other information about domains which the virtual processor is permitted to enter - 4) general management information, e.g. scheduling parameters and accumulated run time. SECTION 2: ENTRY CAPABILITY STRUCTURE AND MANAGEMENT. We have detailed how once a putative entry capability (c-list) is presented to a kernel, the kernels go about gathering all the segments together and schedule the execution of the new domain incarnation. We now look at the process of creating the entry capability list in the first place. Spier's distinction of two types of local segment, incarnation own permanent and incarnation own temporary, gives a starting point for identifying the mechanisms required. Since we permit local segments to pass as parameters between domain incarnations we require three categories of local segments: temporary, permanent and argument. We suppose that the local segment capabilities in an entry capability each belong to one of three sublists: the temporary list or I=list the permanent list or P=list the argument list or A=list Stack organization of entry capabilities: Consider first a system in which all local segments are of the temporary type. Un a computation's entry to a domain the local segments required are created. They exist while the computation proceeds in the domain and while calls are made to other 'inner' domains, to which they may be passed as parameters. They are deleted when the computation exits from the domain. For such a system it is appropriate that skeleton c-lists be kept in a stack in the processor base segment. To enter a new domain a virtual processor executes the code in the old domain to cause the name of the new domain, that is the name of the code and possible public segments, to be placed in a new colist which will eventually be placed at the top of the stack of entry capabilities. This name will normally have been embedded in the code at compile time but exceptionally could have been passed as a parameter to the old domain incarnation. The desired entry point is also stored with the domain name. We could use compile time information and have the code of the old domain specify pseudo capabilities (of the transient type) for the local segments that are to be created for the new domain incarnation. The alternative is to have a template [COHE/5] associated with the code segment and have the kernel at the code site create the pseudo capabilities before it does its 'best' site calculation. This second alternative is to be preferred because the data about the internal structure of a domain is held in just one place, which is in accordance with the principle of information hiding [PARN72], and it leads to less duplication of code. # Parameter handling: In the case where the domain name is known at compile time then the number and type of any parameters taken by the domain can also be specified at compile time. When these parameters are simple variables they can be loaded into an argument stack or area in the processor base segment. When the parameters are for local segments (which must form part of the old domain incarnation) there are two approaches that can be taken. 1) Domains can be permitted to shift capabilities between the T-list and A-list. The code in the old domain can specify the transfer of the segment's capabilities from the T-list of the old domain incarnation to its A-list. The local kernel then transfers the old A-list to the A-list of the new entry capability when invoked to perform the interdomain jump. is permitted to manipulate kernel 2) Only the capabilities and it transfers the entries direct the new A-list. In this case the code places pointers in the new A-list back to entries in the full list of local segments in the old entry capability (see figure When the interdomain jump request is made 6.3). can transfer the 'pointed at' local kernel capabilities to the new A-list, noting in the old c-list to where they were transferred (see figure 6.4). The former of these two approaches is the more flexible but is likely to be less efficient and less secure. For in this approach the A-list becomes simply a receptable for parameter capabilities at the time of interdomain jumps. The entered domain has to transfer the capabilities for the parameters back to a T-list before it can safely access them. Although it saves the kernel a job, this transferring of capabilities back and forth between T-list and A-list could be error prone. Hence we prefer the second approach which leads to more compact entry capabilities at the cost of slightly more work done by the kernel at domain call and return time. Then the A-list always contains the parameters passed to the domain. It has no special relation to parameters passed from the domain to inner domains. of the new domain is not known at the name When compile time, the same action as above can be taken if some form of parameter specification has been given (and checked) at compile time. Otherwise the kernel accept the parameters as given but, before permitting entry to the new domain, it would have to perform a check to ensure that they corresponded to those expected by the Such a dynamic check could turn out to be new domain. both more costly [HANS74] and coarser [HANS73] than one provided at compile time. Figure 6.3 gives an example of the old and new c-lists just before the local kernel is invoked to perform the interdomain call. Figure 6.4 shows the transfer of capabilities made by the local kernel before it sends the c-list off to the site of the code segment (or deals with it itself if the new code segment is already resident at its site). Figure 6.5 shows the situation just prior to the 'best' site calculation and figure 6.6 gives the final form of the entry capability stack when the called domain incarnation is ready to run. START OF INTERDOMAIN CALL Figure 6.3 [A] LOCAL SEG.D [A] LOCAL SEG.B CALLED ENTRY DOMAIN POINT PROCESSOR BASE [T] #2# [T] LOCAL SEG. C [T] #1# [T] LOCAL SEG. A CALLING / RETURN DONAIN / ADDRESS SLOT FOR PROCESSOR BASE STACK OF C-LISTS NEW C-LIST TRANSFER OF CAPABILITIES TO NEW C-LIST Figure 6.4 [T] size=100 [T] size=267 [T] size=900 [A] LOCAL SEG.D [A] LOCAL SEG.B CALLED / ENTRY DOMAIN / ADDRESS PROCESSOR BASE . NEW C-LIST NEW C-LIST AFTER INFORMATION FROM CODE SEGMENT TEMPLATE HAS BEEN ADDED Figure 6.5 | [T] LOCAL SEG.G | |--------------------------------------| | [T] LOCAL SEG.F | | [T] LOCAL SEG.E | | [A] LOCAL SEG.D | | [A] LOCAL SEG.B | | CALLED<br>DOMAIN ADDRESS | | PROCESSOR BASE | | [T] #2# | | [T] LOCAL SEG.C | | [T] #1# | | [T] LOCAL SEG.A | | CALLING / RETURN<br>DOMAIN / ADDRESS | | SLOT FOR<br>PROCESSOR BASE | | | | ( | | STACK OF C-LISTS | COMPLETED INTERDOMAIN CALL Figure 6.6 TRANSFER OF CAPABILITIES AT INTERDOMAIN RETURN Figure 6.7 A return to a domain is also performed by an interdomain jump. If the slots where parameters were passed to were noted (see figure 6.4) then the top two entry capabilities in the entry capability stack contain all the information the kernels require to effect return. (Except that any simple values to be returned must be placed in the parameter area). interdomain jump is requested the local kernel shifts back the processor base segment and all the parameter segment's capabilities (i.e those in the A-list) to the c-list for the domain incarnation being returned to. Then the kernel deletes all segments whose capabilities are in the T-list. The entry capability for the domain being returned to is then validated as before except that there is no requirement for the code segment to supply details of the structure as this is known already. Figure 6.7 depicts the movement of capabilities effected by the local kernel when requested to perform interdomain return. Unfortunately not all computations proceed in the nested fashion mirrored by a stack implementation. One simple example of this is where a computation moves serially through domains. If the first domain in the sequence was passed parameters in a normal call, then all domains in the sequence must maintain the same parameters so that the final domain in the sequence can perform a correct return. Within the sequence of domains a virtual processor wishing to jump to the next domain loads the name (and entry point of the domain) into a new c-list and requests an interdomain jump. The kernel then copies the processor base capability and the capabilities in the called domain incarnation's A-list into the c-list and dispatches the c-list to the code segment site. It also deletes all the local segments whose capabilities remain in the old top of stack entry T-list and removes this entry capability from the stack. The rest of the interdomain jump proceeds as before. # Retaining permanent segments between calls: Greater complications arise when it is desired to retain local segments between calls on the domain. arises when, for example, there is a co-routine structure between two or more domains, or generally in the handling of peripherals which requires the maintenance of buffers and status information. Although it is quite straight forward to devise rules for kernels to know when t place local segment capabilities in the P-list, so that they not be deleted at domain exit time, it is more will difficult to devise satisfactory rules for kernels to to eventually delete segments in the Polist. Consequently we allow a virtual processor to segment in its current domain incarnation between the P-list and the T-list. This gives a greater flexibility than could be achieved by automatic rules. It shifts the responsibility for deleting permanent segments to the programmer. In order to use the local segments whose capabilities are stored in the P-list when a domain is re-entered again, the P-list, or the whole c-list with appropriate empty slots, has to be preserved when the entry capability is removed from the top of the stack. The following is a list of options available: - 1) Abandon the stack of c-lists altogether, keeping a simple table of c-lists for all domains entered or known about, and maintain a separate stack of return links and a pointer to the current domain incarnation. With appropriate organisation this gives quick access to the c-list, which includes at least the P-list, of any domain. This is the approach taken by Spier (SPIE741. It restricts all entry points of the domain to taking the same number of argument segments and using the same number of temporary segments (although null segments could be used sometimes). Further it does not allow recursion of any form. - 2) Maintain the stack but use another area of the processor base segment for storing P-lists of exited domain incarnations. Together with each P-list, an indication must be kept of the domain to which it belongs. For every call on a domain this area has to be checked to see whether there are local permanent segments for the new domain or not. Also for domains with multiple entry points the sequence of calling these has to be controlled, or all entry points must use the same structure of permanent local segments. Recursion using the same instance of permanent segments is possible. - 3) A variation on the previous option is to store the P-list with the code segment templates and maintain separate templates for every virtual processor that has previously entered the domain. This could provide more flexibility than option 2 in the arrangement of P-lists for different entry points but otherwise the properties of the two options are similar. But this is not a good solution. The altering of data associated with the code segments inhibits the duplication of code at different sites. Also error recovery is made more difficult; information about the resources a virtual processor has (defined by the permanent local segments it owns), is throughout the distributed system rather than being concentrated in the processor base segment (which will always be at the scene of any error). - 4) Change the stack to a tree arrangement similar to that used in quasi-parallel programming systems [DAHL72] and some forms of parallel processing [ORGA73]. When, at the first domain exit time, the kernel detects that the P-list is not empty it 'splits' the stack. The c-list being exited from is linked, by the kernel, into the tree as a sibling of the original calling domain. Provided that kernels can distinguish first time entry requests from re-entry requests, full dynamic recursion is possible. In the case of re-entry, a search up the tree may be required to locate the correct c-list. Again care will be required with multiple entry point domains. This option also permits an obvious rule for the ultimate deletion of permanent segments, namely deletion is performed and the tree pruned, when control returns to the parent domain incarnation. But this option confines interdomain calls to conform to a hierarchical structure. Also if two or more P-lists for the same domain incarnation exist with the same parent then some further mechanism is required to identify which P-list is to be used in a domain incarnation. for c-lists. These named c-lists are stored in a separate area in the processor base segment and contain at least the domain name and entry address, and incarnation P-list. They could also contain slots for parameters and pseudo capabilities for the temporary segments (see figure 6.8). These c-lists are put together by a kernel request during the virtual processor's execution in the domain to which the segments pointed to by the c-list belong. The kernel returns a label which can be passed as a simple parameter. The main use of this is to preserve the P-list of a called domain. Before it exits the virtual processor in this domain sets up the label [T] size=900 [T] size=200 [P] PERMANENT LOCAL SEG. [A] SLOT FOR PARAMETER [A] SLOT FOR PARAMETER DOMAIN ENTRY NAME ADDRESS EXAMPLE OF A LABEL C-LIST PROCESSOR BASE SLOT FOR Figure 6.8 c-list and then returns with the label to the caller. subsequent rementry the caller requests For interdomain jump to the label. The local kernel retrieves the c-list and validates it as usual. The order of calls to multiple entry points is dictated by the called domain by way of the labels it returns at the end of each call. The label mechanism can also be used to implement 'call by name' parameter passing, but this is not something to be encouraged in a distributed system. As the connotations of label would suggest, this option is rather primitive. But it can permit full recursion as well as distinguishing easily between multiple uses of the same domain by the same virtual processor. To enter a domain a first time a virtual processor presents an initial entry capability; for subsequent re-entry it presents the returned from the previous entry. If the virtual processor wants to use the same domain for a different purpose (e.g. if it is a file handler domain and the virtual processor wants to open a second file) then it presents an initial entry capability again and will be returned a new label. This is the only option proposed so far that can handle this multiple use situation. 6) Abandon the concept of permanent local segments altogether. Instead generate temporary local segments at an outer level and pass them as parameters through all inner levels to the domain that requires to use them. Also, the public segment of the domain could be used to hold information that would otherwise have been kept in permanent local segments. This solution, as well as violating protection principles, could involve a huge increase in the number and/or size of segments that would have to be shifted from site to site at each interdomain jump. We feel that the fifth option is the best. It could turn out in practice though that the features this option provides are not required, that permanent segments form such a tiny fraction of the total number of segments that the second or sixth arrangements would be better. #### Creating and deleting local segments: One other topic concerning local segments is their creation and deletion during execution within a domain. We permit virtual processors to make kernel calls to delete local segments in the domain they are in, at any time. The capability in the callst is replaced by a null capability. A null capability may be passed as a parameter. This is particularly appropriate in a producer/consumer situation; the producer transmits a full segment to the consumer as a parameter in an interdomain call. At the return no useful purpose is served by transmitting back the segment so the consumer can delete the segment when it has finished with it. The creation of local segments is more difficult as it involves the allocation of a resource, namely memory space, so it could be subject to delays or even the shifting of the domain incarnation to another site. The best time to create new segments is at domain entry time. This is why we provide templates attached to the code segments so that space requirements for a new domain incarnation can be determined before the 'best' site calculation is performed. If it is absolutely necessary for a domain to be able to create segments once its execution has begun, then its request to the kernel to do this is treated as an interdomain jump back to itself. We assume that capabilities for newly created segments belong originally to the I-list. SECTION 3: COMPARISONS. In this chapter we have proposed a domain architecture suitable for distributed systems. We have detailed how, despite the fact that no copying of capabilities is allowed, a quite powerful capability system can be constructed. Uur system does not suffer from revocation of capability problems because 1) it is not process orientated and 2) only one capability exists for each segment (other than code and public segments). If present domain systems are viable on single site systems then our system is powerful enough to be viable on a distributed system. We now identify common points between those domain systems we discussed in the last chapter and our model, and show where improvements have been made. Evans and LeClerc identified three types of local segment making up a domain; fixed, dummy and scratch. These correspond to the segments whose capabilities are kept in our P-list, A-list and I-list respectively. By allowing segments to be moved between P-list and I-list we cater for domain initialization and allow more flexible deletion of segments. have already mentioned what we consider to be the ₩e main inadequacy of Spier's model, the fixed number and type of segments in a domain incarnation. Our model allows any number of local segments, the equivalent of Spier's incarnation own temporary segments. We permit local segments to be passed as parameters between domain incarnations. This eliminates much of the potential inefficiency of Spier's model arising from copying whole segments into and out of the processor base (argument) segment. We are also far more flexible in our handling segments. Using labelled permanent capabilities, our scheme will support a virtual processor having two or more different sets of segments in a domain. There is little to choose between Spier's separation of code and public (domain own) segments, which we have adopted, and having them mixed together as Cosserat allows, provided that a domain which does not have any is identifiable as such. In our previous public data discussion above, and our subsequent discussion of implementation of our model, we always treat the two segments, when they both exist, as a single entity. however a system had plenty of active storage but was lacking in communication bandwidth it is conceivable that the code segment would be treated differently from the public segment; copies of the code segment being There is no point in having copies of public permitted. segments because the machinations required to keep them consistent would far outweigh any advantage gained in not having to shift segments around from site to site to form domain incarnations. We were not aware of Cosserat's work when we undertook the definition of our model, working, as we mentioned before, more from the papers of Spier. There are however quite a few points of similarity between Cosserat's model and ours. Both permit any number of segments to be part of a domain incarnation. Both use the processor base segment for several purposes. Although in Cosserat's model a local segment can be part of many domains at once it is very unlikely in reality that these domains will all be accessing the segment at once (unless the segment is a segment of semaphores). Thus we loose little, if anything, by making our local segments accessible in one domain at a time. Cosserat's indirect entry mechanism is a generalization of our label mechanism. We only permit a labelled c-list to be built up by the domain to which the segments in the c-list belong. But again we feel that we cater for the major use of the mechanism (the handling of permanent or own data) and that further generalization is not required. Cosserat's rule of creating a new base segment for every change of domain brings undoubted advantages when it comes to creating new processes, but its efficacy is more open to question when the number of virtual processors in a system is fixed (a feature we shall expound upon further in the next chapter). There is very little information that can be left behind in the old base segment and not transferred to the new base segment. If the simple parameter area is organised as a set of stack frames then only the frame for the parameters being carried to the new domain need be put in the new segment. Otherwise the only item not required in the new base segment is the old domain's return link. Since processor base segments are the most frequent movers between sites in a distributed system (see the sample results in appendix A) it is important that they be But there is a definite trade off between the small. transmission time saved on one hand and, on the other hand, the extra copying involved. Splitting up the processor base segment may also cause the occasional delay, when doing a return, when all the required segments save the old processor base are at one site. Only experimental evidence from real implementations can resolve questions such as this and the questions we will be raising in the next chapter as we examine more facets of distributed systems. # CHAPTER 7 DISTRIBUTED SYSTEM METHODOLOGY The last chapter presented a model for a distributed system in terms of segments, capabilities and domains. We did not specify what was to be the function of any of the domains, nor did we indicate how a programmer might go about constructing a domain. We now direct our attention to these and similar topics. This chapter is concerned with the wider perspective of distributed system design. #### SECTION 1: RESOURCE ALLUCATION. For some years now there has been a school of thought that advocates the limitation of forms of dymanic behaviour in operating systems [HANS73,HANS74,HOAR74a, HOAR74b,HANS76]. The THE operating system [DIJK68] has a fixed number of virtual processors. The recently completed SOLO system [HANS76] has not only a fixed number of virtual processors but is conceptually compilable as a single program, so that all interactions within the system are able to be checked at compile time. We concur with such sentiments, as they lead to a fresh view of resource allocation which we believe is suitable for distributed systems. Systems with dynamic creation and deletion o f processes usually handle resource allocation on a hierarchical basis. All the system resources initially vested in an ultimate ancestor [HANS73, SEVC74]. Whenever a process is created it is given some of the resources of the creator process; if not 'consumed', the resources are returned to the creator process when the new process is deleted. The ultimate ancestor represents a potential bottleneck since it has to deal with all the systems resources. In our distributed system resources are associated with domains, allowing control to be spread throughout the system. Each virtual processor can enter any domain (known to it) and access the resources in it. But the virtual processor must execute the code of the domain while accessing the resource. Thus the domain can control all its resources, all of the time. This form of distributed control does not preclude the use of process hierarchies but it does remove a lot of the justification for them. Ability to freely create processes could also be troublesome if it is desired to limit the total resources available, at any one time, to a user. If we were to allow a process to control the progress of another and even destroy it, as is permitted in many process orientated systems [KNOT74], then a process would have to be a global object. This follows from the requirement to locate the process that is to be controlled or destroyed. The management of global objects is relatively expensive. The number of processes would grow in proportion to the number of sites, presenting larger and larger directory or associative memory requirements. Overall, considerable simplicity and efficiency is gained by having a fixed number of virtual processors (which are not global objects), one virtual processor per user. If some form of parallelism is required a user can be permanently allocated more than one virtual processor; in the SOLO system he is given three, one to handle input, one for computation and one for output. #### Domains: Since a system is likely to have a fixed maximum number of resources for long periods of time it is logical to have a fixed number of domains to manage these resources. We include as resources compliers, editors and anything usable by more than one user. Using a fixed number of domains confers two advantages: 1) Every kernel, as part of the management of global objects, needs to keep information about every domain. With a constant number of domains, fixed space for this information can be allocated inside kernels, leading to more efficient operation of the kernels. Of course when there is an increase in the number of resource types in the system a recompilation of the kernel will be required. 2) The finding of a domain is considerably simplified if it always exists. When a kernel receives a message related to a domain that does not reside at its site, it need only pass the message on to the site where it believes the domain to be. Provided that the message travels faster than the domain (see chapter 8) it will eventually reach the correct site. If domains were dynamically created and deleted then the kernel would have to decide whether to pass the message on to another site, or initiate the creation of the domain, or regard the message as being for a deleted domain and hence erroneous. Having a fixed number of domains in a system is not an absolute fiat. Arrangements could be made for the locating and loading of some domains from a file store when required (an obvious exception is the basic domains that manage the file store), in a similar fashion to Spier's implementation. As well as the added complexity in domain management described above, knowing when to unload the domains again is likely to be a tricky problem. So far we have been careful to avoid mentioning user code. We have adopted the attitude of Hoare [HDAR74b] towards user code. He believes that all user code should be interpreted by the operating system. He reasons that a user cannot compromise the security and robustness of a system if all (sensitive) operations are vetted by the operating system. Our adoption of this philosophy allows us to have a fixed number of domains in our distributed system since users do not generate their own domains. We provide a user supervisor domain. One, or more, of the local segments in an incarnation of this domain is user code. The user supervisor 'interprets' this code. In practice this would mean that the user code is directly executed but the domain fields any 'supervisor' calls, which it translates to interdomain calls. There is no compelling reason why the appearance, to a user, of a system should bear any relation to the structure used to implement the system. Placing user code in a supervisor cocoon means that the ordinary user need not be appraised of domain structures when it comes to writing his own programs. Interpretation also provides a hook upon which can be hung such facilities as execution time limits, error diagnostics and recovery, and console generated interrupts. Unfortunately this approach also rules out the sharing between users of the same copy of user code. If some user program is in such demand that the likelihood of two or more people using it simultaneously is significant then the program could be incorporated into the operating system, either directly as a single domain, or, in a rewritten form, as several domains. SECTION 3: ADDRESSING. Addresses in capabilities: Another topic we have not yet touched upon is the form of addresses stored in capabilities. Capabilities always reference segments residing at some site in the distributed system. When a segment is said to reside at a site we mean that the segment is stored in the private active storage of that site. The active storage may be simply primary memory or could consist of backing store as well, provided that the backing store is controlled solely by the site. (In the later section on peripheral handling we show that problems can arise with shared control of backing store devices). A segment's address, as stored in a capability, is assumed to be in two parts. The first part specifies the site where the segment resides. The second part is some form of address to be interpreted by the kernel at that site. This second part could consist of: - a segment starting address (only suitable for one level memory and not allowing any repacking of memory) - 2) a segment table offset (allowing backing store and repacking) - 3) a key for a segment hash table (also permitting backing store and memory repacking). The third approach is likely to be the best in a real system because it gives more compact segment tables and, if the keys are made unique system wide (FABR/4), it provides a useful robustness (LAMP/4). ## Moving segments between sites: A capability for a segment also has a length field and both this field and the segment address play a role in the movement of segments between sites. When a kernel has accepted a domain incarnation c-list, it initiates the transfer to its site of all segments of the domain incarnation. The kernel scans each capability in the c-list and determines the location of each segment from the first part of the segment address. From the length field the kernel determines how much memory space each segment will require when it arrives. The kernel could allocate the space there and then. The kernel sends a message to each site that has one or more of the segments it requires, specifying each relevant second part of the segment address and requesting the segment be sent to it. When each segment finally arrives, its capability in the c-list is altered to reflect its new address. When all the segments whose capabilities are in the c-list are at the kernel's site, then the c-list is marked as a valid entry capability and the domain incarnation is ready to run. The action taken is slightly different in the case of code and public segments, for the capability for these is just a name (see chapter 6, section 1). The kernel which wants the segments sends a message to the site where the segments are residing (located with the aid of tables or associative mechanism in the communication subsystem). The segments are sent to the requesting site when they are no longer required at their current site, and action is taken to appraise all the kernels of the new site for the segments. (More details are given in chapter 8). The advantages of pre-loading all segments of a domain incarnation, rather than requesting segments piecemeal from other sites as they are required, can be deduced from the above description. Firstly, all segments required from a particular site can be requested with a single message, saving some communication bandwidth usage, and, far more importantly, interrupting that site only once, rather than for every segment. Secondly, the total (extra) space requirement of the domain incarnation can be determined before any segments are requested from other sites. Thus if the site has insufficient space for the domain incarnation the appropriate action, normally sending the c-list to another site, is taken before any segments have been transferred to the site. ## Capability hardware: The generation of addresses within a domain incarnation must be in the form of an index into the c-list to select a capability for a segment followed by an offset within the segment to select the required item. This obviously enforces the confinement of all accesses to be within the domain incarnation. It depends on the hardware facilities as to how the physical processor uses capabilities. Since each domain incarnation's capabilities are stored in the capability or c-list for the incarnation the use of a fixed, and reasonably modest, number of capability registers is one option available. This is the approach used in the Plessey 250 [COSS72, ENGL74]. When a domain is ready to run, the kernel loads the hardware capability registers with the capabilities in the c-list, suitably translated to hardware addresses. Since postulated that a domain incarnation should last for some overhead of loading perhaps 16 appreciable time, the registers at the start of a domain incarnation and unloading them again when an interdomain jump is requested, should not be too large. This is provided that these registers do not have to be unloaded and loaded again every time the kernel receives an interrupt of any sort. As we indicated in chapter 3, the volume of interrupts will grow as the size of the distributed system grows and the preservation of context could quickly become a dominant unproductive factor. The operation of the Plessey 250 has been described by the "Don't interrupt me, I'm computing" [HAYN73] because external interrupts have been abolished [ENGL72]. This extreme philosophy need not be employed in a distributed system provided that kernel operation is clearly differentiated from execution in a domain incarnation, and simpler context switching is provided for the kernel. Alternatively a set of associative capability registers similar to those used in the CAP system [NEED72] could be employed. This would allow entry capabilities of arbitrary (or near arbitrary) length, that is large numbers of segments in a domain incarnation could be accomodated, but not all of them could be accessed quickly. The whole c-list need not be loaded at the start of a domain incarnation, entries would be added to the associative registers the first time the capability was used. Further, appropriate design could ensure that the contents of the associative capability registers remained usable after the handling of an interrupt and even after an interdomain jump and subsequent return (assuming the entered domain did not require the use of all the registers for its own c=list). SECTION 5: PROGRAMMING LANGUAGES. ## Constructing domains: The code that constitutes code segments has to be written by someone. We now look at how appropriate present languages are for the task. Our particular interest is in the representation of segments and their manipulation to form domains. High level languages offer the programmer segments in many guises. In arrays the offset within a segment at which a data item resides is obviously specified by the index. Other structures (e.g. RECORDS in the IMP language (STEP74)) have symbolic names for the various data items in segments, it being one of the functions of compilers to map these names into offsets. Most languages however do not offer the programmer any means of specifying domains. Automatic rules could be devised for constructing domains from programs in many languages, but the efficiency, particularly in our distributed system, of such automatically created domains is open to question. Such domains are likely to be so small that the overheads involved in domain changing will dominate the useful work done in the domain. For example, in ALGOL 60 the only two possible automatic rules are to make the whole program into one domain or to make every procedure the basis of a domain. In the B6700 system [ORGA73] the code for every ALGOL procedure is put in a separate segment. A recent study [BATS76] suggests that the average number of instructions executed from each code segment each time it is entered is of the order of 50 to 100. This is too few instructions to carry the overheads of domain entry so the ALGOL procedure is not a suitable basis for a domain in our system. FORTRAN does provide a way of generating larger domains than just individual subroutines. The COMMOM block is a suitable structure to be made into a segment. Sometimes it may be possible for all subroutines to be divided into disjoint sets accessing different COMMON blocks in which case domains can be constructed with a code segment containing the set of subroutines, and with local segments containing the mutual COMMON block(s), all other local data, and arrays. When it is not possible to form disjoint sets of COMMON block accessors then some sort of programmer intervention is required to identify which COMMON blocks are to be used as the basis of domains and which should be passed as parameters between domains. This requires the same sort of techniques that are used to identify overlays [SELI72]. SIMULA 67 [DAHL66, DAHL72, ICH874] provides in its 'class' concept a programming analogue to domains. A class defines both data objects and the operations, in the form of procedures, to be performed upon them in the same way that the code segment of a domain incarnation defines the operations that are performed on local segments. However in programs these procedures are likely to be very short so that domain changing to enter a class may have unacceptably high overheads. Further in SIMULA 67 access to the data (attributes) of a class is permitted directly without executing one of the class procedures. Nevertheless a restricted form of SIMULA 67 could provide a suitable basis for developing a language for domain handling. Quite a number of languages provide facilities for separate compilation of parts of a program. There are variations on how much compile time or link time checking is performed. Complete checking is feasible when there is no recursion between separately compiled parts. In some circumstances it is reasonable to assume that these 'external' portions constitute the basis for a domain in that they perform a definite part of a computation. Uf course, often these separately compiled sections provide a service environment for the rest of the program so that the frequency of use of the separate sections is high and the duration of residency is low. But, again with appropriate discipline, the separate compilation facility does provide a basis for the construction of domains. To summarise, our desiderata for a programming language in which to write domain structured programs include provision for the manipulation of segments as basic items, and structuring rules that lead to easy specification of appropriately sized domains. The entry points to a domain must be obvious. This can be achieved by specifying routines to be 'external' [STEP74], or negatively by employing the 'hidden' feature proposed for SIMULA 67 [HOAR74b]. ## Language restrictions: So far we have looked at features that would be conducive to efficient domain structure. Attention is now turned to two language features, the usual generality of which would have to be severely restricted in a domain system. These are parameters and pointers. The parameter passing mechanisms of many high level languages are too sophisticated for our model to implement efficiently. The model provides in effect the same parameter passing mechanisms as FORTRAN: call by value (with possible copyback) for simple variables and call by reference for arrays (segments). That this, in way, is sufficient is demonstrated by the large some number of running FORTRAN programs in existence. we would wish, domains embody some complete and quite substantial function then the dictates of good design suggest that the number of parameters to be passed between domains should be small and that possible complexities of side effects and so on should be avoided Hence we feel our model's mechanism to be [PARN72]. adequate; the type of parameter passing employed within domains need not be restricted to that possible between domains. Pointers, that is stored memory addresses, recently fallen into disfavour with some programming experts [WIRT74] because they lead to an item having two or more names, and hence detract from program clarity. In our distributed system any pointer to an address in another segment would cause immense difficulties. would be two ways of storing such a pointer. would be to store the full capability of the segment (plus offset) which violates our principle of having only one capability in existence (for local segments) and keeping that capability in a fixed location. The second method would be to store the calist offset of the segment (and offset within the segment). Problems would arise if the segment containing the pointer was passed to another domain incarnation because then the pointer would be Thus in capability systems such as ours the use of intersegment pointers cannot be supported. made no mention of public segments We in our discussion of programming languages. Only two languages, that know of. embody such a concept directly. W @ Concurrent Pascal [HANS74, HANS75] is the original of these two. Details of the second language language SIMUNE, which is similar to Concurrent Pascal, have been published very recently [KAUB76]. One of the elements of languages is a 'monitor'. Monitors, before being incorporated in Concurrent Pascal, were developed by (HDAR73, HDAR74a) and Hansen [HANS73]. A monitor consists of some data, and procedures to manipulate the Monitors have the following properties: data. - 1) the data of a monitor is global in the sense that only one instance of the data exists, thus corresponding directly with data in a public segment. - 2) the monitor data is only accessible to the monitor procedures; all manipulation of the data is by calling these procedures, just as a domain must be entered to access its public segment. - 3) at any one time, at most one virtual processor can be progressing in a monitor; it will maintain exclusive access to the monitor's data until it exits from the code (or suspends itself on an internal queue), thus allowing guarantees to be made about the integrity of the monitor's data. The finer details of monitors' properties have yet to be agreed upon. For example Hansen has his monitors contain global data only [HANS75] while Hoare's monitors contain both global data and multiple copies of user data (equivalent to local data) [HUAR74b]. It is on the basis of Hoare's type of monitor that we named domains having a public segment 'monitors'. ## Exclusive access and the condition queue: Another undecided property of monitors is that of how long exclusive access to a monitor should prevail. Obviously when a virtual processor finally exits from a monitor access can be given to another virtual processor. The problem arises when the virtual processor makes a call to another domain. Should all other virtual processors be denied access while this call is in progress? To do this poses far more management problems [LIST76] than the approach we have adopted which is that whenever a virtual processor executing in a monitor makes a call on the kernel (as it will to change domains) it looses kernel guaranteed exclusive access. To allow longer periods of effective exclusive access and to facilitate certain forms of virtual processor intercommunication, monitors have to provide a facility whereby a virtual processor can suspend itself while waiting for some condition to be fulfilled (by some other . . virtual processor). When it suspends itself the virtual processor looses exclusive access to the monitor. Hansen provides a general queueing mechanism in a monitor so that other virtual processors can manipulate the queue (called the condition queue) in any desirable fashion. Hoare is more strict; condition queues have to be served either 'first in first out', or in order of a priority specified when joining the queue. We stated in chapter 6 that kernels kept validated entry capabilites in some form of 'ready to run' queue. The running domain incarnation is at the top of the queue so that its suspension involves removing its entry capability and storing it in the condition queue of the monitor. The condition queue has to be part of the public segment. It is no good making it part of a kernel area unless the monitor is to be tied to a particular site. No major problems arise with entry capabilities being moved, undetected by kernels, from site to site. When another virtual processor, executing in the monitor, wishes to release a suspended virtual processor it removes the entry capability from the condition queue and passes it to the local kernel which re-validates it. Eventually the domain incarnation will be scheduled for execution again. One difficulty in following Hansen's approach of allowing general manipulation of the condition queue is that suitable constructs must be provided for the domain code to examine the capabilities in the condition queue. We cannot see any neat way of providing these. #### Secretary processors: The original impetus for monitors came from Dijkstra's 'secretary' concept [DIJK71]. In a process orientated system a secretary process maintains global data, all requests to manipulate it being sent as messages to the secretary. In a monitor type system virtual processors can enter the monitor themselves to manipulate the data. However, particulary when dealing with peripherals, situations could arise where the kernel cannot know which virtual processor should be dispatched, to answer an interrupt, for example. Thus in our model we make provision for some monitors to have secretary processors (or daemons (SALT66J) associated with them. These special virtual processors execute only in the monitor and may use different code from the normal monitor user. Their purpose is to provide general housekeeping functions on the data structure that constitutes the public segment. Secretaries have a special relationship with kernels. Peripheral interrupts are associated with unique secretaries. When a kernel recognises a peripheral interrupt it schedules the appropriate secretary processor to run. When this secretary processor runs it can manipulate the queue of the monitor to which it belongs to have the correct virtual processor scheduled. While this arrangement certainly gives flexibility in handling I/O devices we are not so sure of its efficiency. We postpone discussion of this to chapter 11. ## SECTION 7: PERIPHERAL HANDLING We have just shown how the secretary processor concept can aid in the management of peripherals. Using secretary processors however is just one approach to managing peripherals in a domain structured distributed system. There are a number of possible approaches depending on the functional capabilities of peripheral controllers. In this section we propose various schemes for handling disk operations, predicated on the intelligence of the disk controller. We have chosen disks as an example because: - 1) they could be quite heavily used so that inefficent operation is less tolerable than for some other peripherals. - 2) disk usage involves reading and writing, a read possibly being of something previously written. The second point has ramifications for distributed control which we point out later. We assume that the unit of reading and writing is a segment, more specifically a local segment used as a parameter. A write involves passing the segment to the disk handling domain which on exit returns a null segment. A read involves simple parameters and a null segment being passed to the disk handling domain and a full segment is returned. #### The workstation approach: Undoubtedly the neatest scheme is to assume that the disk controller or other peripheral controller is a site in its own right, fully integrated into the communication system. When using a bus type communication subsystem, which does not require more links as more sites are added, a network architecture such as depicted in figure 7.1 can be achieved. With the advent of microprocessor controllers the workstation concept, as embodied in the CDC 7600 system [ELRO70, JONE71], is becoming practicable for more modest sized systems. Uf course, in a distributed system, the workstations do not serve a single large processor but rather interact with all the general purpose sites in the system. The workstation must, to all intents and purposes, behave like any other site in its interactions with other sites (internally it could be rather different in structure). This site will have only one domain but must be capable of handling entry capabilities correctly. A DISTRIBUTED SYSTEM USING WORKSTATIONS Figure 7.1 Thus for example a request for a disk read would be programmed as an interdomain call on the 'disk controller' domain. The entry capability would arrive at the disk controller which would validate it as usual and queue it in an equivalent of the 'ready to run' queue (but presumably so as to optimise disk accesses). When the read had been performed the disk controller would initiate an interdomain return, with the read data being an argument segment to be returned to the calling domain incarnation. This approach can be viewed as multiplexing virtual processors on the physical processor of the disk controlling site. One requirement of this appraoch is a large buffering capacity at the controller site because the argument and processor base segments do not immediately leave the site when the incarnation has terminated (i.e. the disk operation has been completed). They stay there until a site has been determined for the resumption of the calling domain incarnation and the kernel of this site then requests the segments to be sent to it. One objection to this scheme that could be raised is that the general purpose power of a microprocessor is being dedicated to a single job in which it could be considerably underutilized. In so far as the the processing power is general and being underutilized this is a valid objection. But the architecture of a peripheral controller is likely to be rather different from a general purpose computer and since the capacity of a peripheral can be quite easily determined, the power of the controller can be matched to the capacity. Substantial underutilization of peripherals may be unavoidable in small systems but for larger systems it is an indicator of bad design. # Limited capacity controllers: This is the scheme that we chose to simulate (see chapter 9). Basically it supposes that a controller will not be designed specifically to fit into a domain orientated system but will be capable of using the communications subsystem to transmit segments and a limited repertoire of control messages to and from other sites. A domain, the disk handler domain, is required to reside at some site to assist the disk controller in its work. Whether this domain is tied down or not depends on the sophistication of the controller, the communication system and the kernels in handling interrupt type signals from the controller. The disk handler domain needs to be a monitor with an associated secretary processor, so there are fewer problems when it is tied to one site. This approach assumes that the disk controller has a number of buffers for holding segments and that it sends a message to the controlling site (i.e. the site where the disk handler domain resides) whenever one of its buffers becomes free. This message is interpreted, by the receiving kernel, as the secretary processor's entry capability for the disk handler domain. The kernel duly validates this entry capability and so eventually the secretary will run. It will initiate a read or write if there are any outstanding, or set a flag to indicate to any other virtual processor that subsequently enters the domain that it may initiate its own read or write because there is a buffer available. It was to avoid congestion at the disk handler site that we introduced the pseudo capability states of 'ondisk' and 'desc' (chapter 6). When a virtual processor wishes to write a segment to disk, it transfers as a paramter to the disk handler incarnation simply a descriptor of the segment, not the segment itself. This descriptor is placed in a queue of descriptors of segments waiting to be written to disk and the virtual processor exits immediately from the domain (unless the queue is full). When the disk controller has a free buffer into which it can receive the segment a request for the segment to be dispatched direct to the disk controller is sent to the kernel of the site where the segment is still residing. Normally reads are executed before writes. A virtual processor enters the diskhandler domain with simple parameters decribing the read. Instead of the processor suspending itself to wait for the segment to be read then returning to the calling domain the entry capability for the return is prepared, including one segment capability marked 'ondisk'. This entry capability is not validated until the disk read has taken place into a buffer in the disk controller. (In fact this invalid entry capability could be sent to the disk controller as the read request and be returned to the controlling site when the read is complete, whence the kernel there starts to validate it). When a site has been chosen for the incarnation of the calling domain to resume, then the kernel of that site sends a request for the read segment direct to the disk controller. The disk controller dispatches the segment from one of its buffers. Notice that in a real system a check, on the queue of descriptors of segments that are waiting to be written to disk, will have to be made before a read is performed. A situation could easily arise where a virtual processor is trying to read a segment that it had previously written (that is called the diskhandler domain and returned) but which segment has not in fact got as far as being written on the disk. This is one reason why it is not possible to have every site control the same disk (perhaps as a kernel function). Unless a virtual processor is going to be held up until a disk write is acknowledged as completed, a single list of outstanding writes for each disk is required. Thus notification of writes to a particular disk must pass through a single site. The other reason that all sites could not control a shared disk is related to buffer management. There is a limited number of buffers in the disk controller, the freeing of one of these buffers indicating that the controller is capable of accepting another request. Although conceivably the disk controller could broadcast that the buffer was free, all the sites would have to agree on which site was permitted to make the next request. The necessity of having all sites in agreement is something that we have studiously avoided, it can be a very time wasting function in a distributed system. ## Plain dumb controllers: It could be that the peripheral requires direct attachment to a central processor for control and has no buffers so that it must transfer directly to or from the main memory of the controlling site. Iying the domain that uses the peripheral to the site, and utilizing the secretary concept to handle completion interrupts and general housekeeping, may well be acceptable when the peripheral is lightly used. But if the peripheral is heavily used, as might be the case for a disk, then the controlling site is likely to become very congested. Before data can be written to disk it has to be moved to the controlling site where it is queued to be written. Data read from disk will initially go to the controlling site where it will exert an influence on the domain that ultimately uses the data, so that that domain will tend to migrate to the controlling site as well. Alternatively the controlling site could be 'split' into two sites, partitioning the memory and sharing the physical processor. One site would have a normal kernel and the other would perform the disk controller function we described in the independent workstation section. This scheme, although it would involve extra software to share the computer between two 'logical' sites might be ideal for a small system that was going to expand. As the use of peripherals grew they could be given their own independent sites, freeing the original sites to concentrate on the expanded workload. This is analogous to conventional small computers doing their own terminal handling but as a system grows this function is taken over by front end processors. #### Efficiency: The schemes we have described illustrate the dichotomy of dedicating processor power to a single task and risking underutilization of the processor, versus doing the task with a processor at a general site, but, because of the special nature of the task, distorting the loading of the site. All the schemes we proposed however suffer in comparison with message passing schemes employed in process orientated systems when we consider the loading on the communication subsystem. For in a message passing system a peripheral is viewed as a sink or source of messages. No domain incarnation is required at the peripheral controller or handler site, saving at least the movement of the processor base segment from the controlling site to the peripheral controller or handler site and back again. Of course the validation of the returning domain incarnation gives an opportunity for it to move to another site to help load balance. There is no equivalent opportunity in a message passing system. Whether this offsets the extra communication costs we do not know. We raise the question again in chapter 11. # SECTION 8: FUNCTIONAL SPECIALIZATION. The workstation approach to handling peripherals can be extended to cover any functionally specialized site. If the site behaves as if it had a (basic) kernel and a single domain which implements the special function then it can easily be integrated into our distributed system. A frequently proposed form of distributed system [FOST72,SELI72,COLO76] gives, in our terms, every domain a site of its own. The physical processors at these sites (inevitably microprocessors) are tailored to the domain resident at them. We have already indicated, in chapter 2, our scepticism of the effectiveness of modest sized systems of functionally specialized processors. We concede that because of the smooth demand presented by a very large number of users, functionally specialized sites may be appropriate for large systems. This is providing that the overall system is balanced for the load applied. However systems such as ours necessarily precede the implementation of such large systems because, for these large systems, good estimates are required of the usage of each domain. Without this information bottlenecks are almost certain to be designed into any such system built. Our system could also mature into a system of functionally specialized sites as it grew in size; specialized sites could be added if they proved cost effective. # SECTION 9: DEADLOCK AND DISTRIBUTED CONTRUL. Spier, when discussing requirements for code segments, stated that they must be re-entrant so as to avoid deadlock between two sequences of interdomain calls, such as A->B->C and C->B->A [SPIE73a]. When used for pure domains and monitors that do not have condition queues re-entrancy will indeed permit deadlock to be avoided. However there is no such guarantee when dealing with monitors that have condition queues. If a virtual processor in a monitor wishes to retain, in effect, exclusive access while it calls another monitor, it needs to set a public variable so that other virtual processors entering the monitor will test the variable and suspend themselves on a condition queue. In such a situation two virtual processors attempting the call sequences A->B and B->A respectively, where A and B are monitors that have condition queues, can be deadlocked. The banker's algorithm for avoiding deadlock, of dubious usefulness in single site systems because of computational overhead [HANS73], is useless in a distributed system because it requires that allocation of resources be centralized. Thus to avoid deadlock of interdomain calls, we require a hierarchical ordering of monitors that have condition queues. A virtual processor that has entered, but not exited, a monitor at a given level can only call monitors at higher levels. Thus the circular calling sequence required for deadlocks is broken. Checks that monitors obey this calling rule can be applied at compile time. Unfortunately, it is not only when dealing with interdomain calls that deadlock can occur in a distributed system. Implicit over-allocation of resources leads to deadlock. For example, if too many virtual processors are permitted to operate in a distributed system then there will not be enough memory space at any site for an interdomain call to proceed. If no interdomain calls can proceed then no virtual processor can finish its work and release memory space. The system will be deadlocked. Since allocation of resources can be performed at site in a distributed system then over-allocation could easily result. Allowing each site a fixed quota of system resources is one obvious method of control. to fix quotas that ensure over-allocation never occurs is to condemn a system to almost constant under-utilization of resources and negates the purpose of joining the sites the system together in the first place. allocation can be done more intelligently if the allocator has some knowledge of the state of distributed system. To this end we advocate the exchange between kernels of a couple of carefully parameters of the load at each site. We have already outlined, in chapter 3, the mechanisms that can be used to effect this exchange of information. Durs is a pragmatic approach to deadlock avoidance. Providing information about global status cannot negate the possibility of deadlock occurring. But the frequency of deadlock can, by altering appropriate 'twiddle factors', be brought down to an acceptable level. In this context it is worth quoting Hoare, 'There is no a priori reason why the attempt to split the functions of an operating system into a number of isolated disjoint monitors should suceed....' [HDAR74a]. The question is just how much information do isolated monitors (kernels) need in order to compete with hierarchically controlled systems, often silted up with too much information, and subject to the delays of bureaucracy. We believe that just a few bytes of information about the global state of a distributed system will suffice. SECTION 10: SUMMARY. This chapter has presented a miscellany of items connected with the implementation and operation of a distributed system. Not every function required for a distributed system needs to be developed from scratch. Those functions of a single site system that do not, or need not, rely on system wide shared memory can be adapted, with little, if any change, for distributed systems. Addressing is modified by the addition of a site identifier, indicating where in the dispersed memory of a distributed system the address refers. The concepts of semaphores and conditional critical regions, which require common memory and a central queue of suspended virtual processors respectively, cannot be readily used in distributed systems, but monitors, with condition queues, can be used, because they localize the management of waiting virtual processors to single domains. the banker's algorithm is unsuitable for deadlock avoidance in distributed systems but the hierarchical ordering of calls, enforceable at compile time, can be adopted without change for a distributed system. Our requirements for language development stem from the particular form of distributed system, domain based, that we have chosen. While developments in programming languages, particularly recent developments in programming concepts for handling concurrency, mirror many of the features of our model for a distributed system, languages developed so far are wedded to single site systems. They offer no help in constructing reasonable sized domains, their parameter passing mechanisms are too general to be efficient and many of them permit references or addresses to be program data which is only feasible when the whole program resides in the same address space. But the requirements for a language for writing distributed systems are not esoteric and we do not think the design of a suitable language will be difficult. However distributed systems do require some new techniques. One example is peripheral handling, when peripherals are considered as free standing entities not controlled by one particular site. Another example is the need to encode the state of each site into a few bytes of information and exchange this information between sites so that resource allocation decisions can be made with reference to the global state of the distributed system. The whole technique of managing domains is of course different for distributed systems. Although we presented the basics of domain management in chapter 6 there are still some important aspects of domain management to be dealt with. Having presented a picture of some of the wider operational aspects of distributed system in this chapter, we return, in the next chapter, to the narrow details of domain management. # CHAPTER 8 DOMAIN MANAGEMENT This chapter is concerned both with the protocol for the movement of code and public segments and with the determination of where domain incarnations should take place. It continues the development, started in chapter 6, of the mechanisms required for handling interdomain jumps in a distributed system. To aid the clarity of the following description we have altered our use of the term 'domain'. We have stated before that the code segment and possible public segment identify a domain. We now actually equate the domain with these segments. Thus when we write of domains being at a site or being moved from site to site, what we mean is that the code segments and possible public segments are at a site, or are being moved. ## Introduction: Code and public segments are the only segments shared between virtual processors and hence great care must be exercised in moving them from one site to another. Problems that could arise include the moving of segments away while they are being used, moving them away after an entry capability referencing them has been put in the ready to run queue or never moving them because there is always some entry capability in the ready to run queue which references them. Management of domains then requires that they are not moved prematurely and that all sites will get access to them within a reasonable period of time. A kernel of a site can receive three types of message or request related to a domain: - 1) A request, in the form of a putative entry capability, to perform a 'best' site calculation for an incarnation of the domain; called a c-request. - 2) A request, also in the form of a putative entry capability (but with a suitable distinguishing tag from the above c=request), to execute a domain incarnation. That is, the site has, been chosen as the 'best' site. This we call an e=request in this chapter. 3) A request to transfer the domain (the code and possible public segments) to another site, called a t-request. A site will only receive these requests if it is supposed by other sites to have the domain resident at its site. We call a site which is supposed to be the site of residence of a domain, the target site for the domain. The correspondence between target and reality depends the method of global object management (chapter 3). In an associative scheme the target is the same for all sites. Also if the updating of the associative memory in the interface unit is performed as soon as a domain arrives then the target site will (almost) always be the correct site. In a system that employs the updating of directories the target for a request could be quite out of date; the directory entry could be changed after the request was addressed and put in a queue for transmission, the message to update the directory could be delayed. In what follows, we assume a distributed system using directory updates, as it is obviously the more difficult case, and we make our strategies robust against old information. Pure domains: The management of pure domains is easier than dealing with monitors so we describe a strategy for pure domains first. In our distributed system there is one original of a code segment of a pure domain and possibly many copies. Whenever a kernel receives a terequest for the code segment of a pure domain, the original of which is residing at its site, it sends off the code segment immediately but keeps a copy. The kernel then decides what to do with the retained copy: - 1) If the domain was being used when the t-request arrived, or there is some 'ready to run' incarnation of the domain then the copy is kept. - 2) If the domain is not required and the kernel is short of memory space then it deletes the copy to free space. - 3) If the domain is not required but there is already sufficient space at the site then the copy is kept so that there is no need to fetch the original from another site if the kernel's site is subsequently chosen as 'best' site for another incarnation involving the same domain. The original is sent from site to site because the sending site may have no use for the code and so could reclaim the space occupied by it immediately, whereas the requesting site obviously always has a requirement for the code. Immediately prior to sending the code segment to the new site the kernel broadcasts the identification of the new site so that other sites can update their directories. The other sites sending messages related to the domain will, eventually, having updated their target site, send the messages to the new site. If a t-request arrives when either there is only a copy or no segment at the site then it is passed on to the target site for the original. But if the kernel has itself sent off a t-request then it 'reserves' the domain for the site of the incoming t-request. The kernel sends off the original of the code segment, keeping a copy, as soon as it arrives. If a t-request arrives after the kernel has reserved the code segment for another site then it sends the t-request off to that other site. A chain of sites, each having reserved the domain, could build up if there were delays in the segment being transmitted from site to site. When a c-request, a request to have a 'best' site calculation performed, arrives at a site the kernel follows one of the following courses of action. - 1) If the original of the code segment is present then the 'best' site calculation is performed and the entry capability validated as usual. - 2) If a copy of the code segment is present then the 'best' site calculation is performed. If the kernel's own site is chosen as "best" site then the entry capability is validated as usual, but if another site is chosen then the correquest is sent off to the target site of the original for the calculation to be repeated. This is done to encourage the aggregation of all incarnations of a particular domain to be at one site (see later). - 3) If, when the c-request arrives, the kernel is already expecting the original from another site (that is it has dispatched a t-request), then the c-request is put in a queue to await the arrival of the code segment. When it arrives the 'best' site calculation is performed as usual for all entries in the queue. - 4) If none of the above conditions prevail then the kernel passes on the c-request to the site it considers to be the target site for the domain. Figure 8.1 is a state diagram for the management of pure domains. It details the various transitions and actions (outputs) that can occur when c=requests, t=requests and domains arrive at a site. #### STATES: | 0 | original of domain is at site | ō | original resides elsewhere | |----|----------------------------------|-------------------------|----------------------------| | С | a copy of domain is at site | $\overline{\mathbf{c}}$ | no copy held at site | | T | domain requested but not arrived | $\overline{\mathtt{T}}$ | no outstanding t-request | | R | domain reserved for 'next site' | R | not in chain of sites | | ·M | outstanding work for domain | $\overline{w}$ | no work for domain | Inputs are given in lower case, outputs are given in upper case. When an input causes no change of state and no output it is omitted. Figure 8.1 When we are dealing with monitors we cannot make copies of the segments involved and send off the originals when t-requests arrive. Basically what the kernel does in this situation is to reserve the domain for the site that issued the t-request. It refuses to process any more c-requests for the domain, sending them on to the site that requested the domain, where they are queued up. Eventually there will be no more work outstanding at the site where the domain resides so the kernel can then send the domain off to the requesting site. For the sake of efficiency we introduce a modification to this strategy depending on the type of work outstanding. When a kernel sends off requests to other kernels for the segments required to make up a domain incarnation it notes, amongst the information it keeps about every domain, that there are some 'external segments' outstanding. Also, every time a domain incarnation is placed on the 'ready to run' queue this is noted against the relevant domain. Whenever segments arrive at the site, or domain incarnations finish execution, this information is amended appropriately. Thus kernels can tell whether outstanding work is all at the site or some of it is awaiting the arrival of segments from elsewhere. In the case where some of the outstanding domain incarnations are awaiting segments from other sites, the kernel will still evaluate incoming c-requests after it has reserved the domain for another site. If all the segments specified in a c-request are at the local site already, then that domain incarnation is placed in the ready to run queue but otherwise that c-request is passed to the next site, to be queued for re-calculation. Once there are no outstanding external segments all c-requests are passed to the next site regardless. This modified policy means that a kernel can perform useful work while waiting for a segment to arrive from another site, but it cannot hold onto a monitor indefinitely. Any t-request that arrives after the domain has been reserved for another site is sent to that site. The site which has requested the domain reserves it for the first site from which it receives a t-request, by setting a 'next site' pointer to the requesting site. Thus, again, a chain of sites wanting the domain could be built up. However, because no c-requests (except those involving only segments at the local site) are processed after the first t-request is received, the chain must terminate quite quickly. When the monitor arrives at the first site that it was reserved for, there may be a queue of c-requests waiting to be dealt with. One policy with respect to these is to process them irrespective of whether or not there is a subsequent outstanding t-request. Figure 8.2 gives a state diagram for managing #### STATES: | -11 - | monitor at this site | $\overline{\mathbf{M}}$ | monitor at another site | |-------|-----------------------------------|-------------------------|---------------------------| | T | monitor requested but not arrived | T | no outstanding t-request | | R | monitor reserved for 'next site' | R | not in chain of sites | | IJ | outstanding work for monitor | V | no more work at this site | | E | segments still to arrive | Ē | no external segments | Inputs are given in lower case, outputs are given in upper case. When an input causes no change of state and no output it is omitted. Figure 8.2 monitors which embodies this policy. #### Observations: It remains to be shown that the two strategies we have outlined above give rise to desirable behaviour. Firstly, domains are not removed prematurely from sites in the following sense: if there are any segments being fetched from another site for an incarnation of the domain or any incarnations at the site are ready to run. or indeed running, then the code and possible public segments for the domain incarnation will not be moved relevant domain incarnations have until the Secondly, because either the domain is dispatched to the next site in the chain immediately, in the case of a pure domain, or as soon as all outstanding work is completed, in the case of a monitor, the domain will not remain at a site indefinitely once a t-request has been received (assuming that domain incarnations are of limited duration). Showing that all sites which issue to requests eventually receive the domain, requires more formalized argument. Our first concern is to show that a torequest never gets lost in a closed loop of reservations (each site reserving the domain for its successor with the last site reserving the domain for the first site). We make the following assumptions. - Assumption 1: No site issues a repeat of a terequest until it has actually received the domain and passed it on to another site. - Assumption 2: After a domain has left a site, the target of that site for the domain, can be any of the sites subsequently visited by the domain. The target cannot be any site not visited by the domain since it was last at the particular site. - Assumption 3: The relative speeds of movement of t-requests (and c-requests) from site to site and of domains from site to site is such that a domain cannot always stay one step ahead of a t-request (or c-request). By assumption 1 there can be no loops in the chain of reservations whose head is the site where the domain is currently resident (we call this the main chain), because a site that is in this chain has not received the domain and so does not send out extra t-requests. Nor does a site produce forks in the chain by reserving the domain for two or more other sites. It is possible for temporary independent chains to form. A site issues a t=request and before it becomes part of the main chain a second site, having the first site as its target, sends it a t=request so that the second site is duly noted as 'next site' for the first site. But since the first site is a target for the second site then, by assumption 2, the set of possible targets, direct and indirect, for the terequest of the first site cannot include the second site. This argument can be extended to any other site that subsequently joins the independent chain, so that it is impossible for the outstanding terequest of the first site to arrive at any site in the independent chain and so form a closed loop. By assumption 3 the outstanding terequest of the head of this independent chain will eventually reach the main chain and the whole independent chain will be appended to it. Now that we have shown that no closed loops form we can state that every t-request issued results in a site reserving the domain for the issuer of the t-request. Since, once a domain has arrived at a site where it has been reserved for another site, it is eventually dispatched to that site, by induction the domain will eventually arrive at every site that issues a t-request. The validity of the above conclusion, that every site that issues a t-request will eventually receive the domain, depends on the correctness of the three assumptions listed above. Assumption 1 is a matter of the policy implemented in each kernel. In a directory update system, assumption 2 requires that no update messages issued prior to the domain arriving at a site are accepted by the site after the domain has left the site. This could be ensured by affixing a generation number to each update message and allowing a site to accept an update message only if its generation number is greater than that of the previous update message it But we feel that in a real system it is very received. unlikely that messages will get that out of date before being acted upon. Likewise we feel that in a real system no special precautions would be needed to ensure assumption 3 is correct. A monitor, when it arrives at a have some work to perform before it can move must The original code segment of a pure domain can again. soon as it arrives at a site, but as it leaves behind a copy it would soon run out of sites where it was required. Also communication subsystems may transmit c-requests and t-requests with higher priority than whole code and public segments because the former are likely to be very short. Ιt might be supposed that it would be better for a kernel to broadcast the identity of the next site in the soon as it had made the reservation of the domain for that site. Subsequent t-requests could then be sent to the end of the chain with considerable savings in overheads compared with the strategy we have outlined, normally torequests will arrive at the top of the chain and have to be passed through every site on the chain to the end of the chain. Disregarding the likelihood of long chains building as uр being very small, an equivalent scheme would indeed be possible for associative type global management. But in the case updating directories, such a scheme leads the violation of our assumption 2 and could give rise to a self-contained loop of reservations for a domain. So the extra overhead of passing t-requests down each site in the chain is unavoidable if we are to use a directory update scheme for locating domains. SECTION 2: THE 'BEST' SITE CALCULATION. In the first part of this chapter our concern has been to show that, once it has been decided that a domain incarnation will take place at a particular site, the domain will actually move to that site. We now look at the decision procedure for determining at what site a domain incarnation will take place. The determination of where the next domain incarnation is to take place is the keystone of our distributed system. If domain incarnations are moved around the system too frequently, virtual processors will be subject to extra transmission time delays and the communication subsystem may become overloaded. If movement is too infrequent then the loading at different sites can be become seriously unbalanced, some sites idle while others are choked with work. In discussing the DCS system in chapter 4 we criticized open bidding for work by all sites as taking too long and putting too great a load on the communication subsystem. Our approach can be likened to a single tender policy. An attempt is made to identify a site that will run a domain incarnation quickly and preferably with minimum demands placed upon the communication subsystem. This site, the 'best' site, is passed the entry capability for the domain incarnation. The situation at this site, and to a lesser extent in the rest of the distributed system, may have altered significantly between the time of generation of the information upon which the decision was made, and the time when the kernel examines the newly arrived entry capability. So if the 'best' site, on the information available to it, calculates that another site would be a substantially better choice, then it sends off the entry capability to that site. This site also has the freedom to accept or reject the domain incarnation. (A maximum number of transfers can be set to stop the domain becoming a 'hot potato'). So there are two types of calculation to be described, one to nominate the initial 'best' site and the other to decide to accept or reject the nomination. We assume that each site has a table of the number of virtual processors at each site in the 'ready to run' queue, or some similar measure of outstanding work, and a table of the amount of free memory at each site. This information would be gathered from the exchange of status information described in chapter 3. The initial calculation: The initial calculation at the code site considers (normally) only three possible sites as candidates for 'best' site. - 1) the site of the code and possible public segment - 2) the site of the processor base segment and any local segments that are parameters; since they were part of the domain incarnation being exited, the parameters will be at the same site as the processor base segment - the site of any other local segments which, since they were all last used in the previous incarnation of the domain being entered, will all be at one site. If the code segment cannot move because it is 'tied down' to drive a peripheral attached to a particular site then that site is chosen as 'best' site. Utherwise the basic policy is for the code site kernel to consider the total size, at each distinct site, of segments for the domain incarnation. The site with the largest aggregate size is chosen as the 'best' site. So, when all the segments are at the same site that site is chosen, and otherwise transmission on the communication links is minimized. Minimization of communication bandwidth requirements is only one of a number of criteria that can be considered. Before the aggregate sizes are compared there are a number of biases that can be applied to them. - 1) Since the calculation takes place at the code segment site it is possible to know how many other virtual processors are using the domain (i.e their domain incarnations are in the 'ready to run' queue). If the domain were to go to another site then either these domain incarnations would have to follow (if they are re-entered again) or the domain must return to the original site. Hence the size of the domain (the code and possible public segments) can be biased upwards by a factor representing its outstanding work, encouraging incarnations for the same domain to be all at the same site. - 2) The load, that is the number of ready to run domain incarnations, at each of the three possible sites can be taken into account. If the domain incarnation is sent to a lightly loaded site it will be executed quicker than at a heavily loaded site. And if transmission times are less than average execution times, substantial advantages accrue by choosing an idle site rather than a site with even one other domain incarnation to run. Thus sizes can be biased downwards by a factor representing the overall load at a site. - 3) A kernel is likely to spend a lot of its time on memory management if it has very little free memory left. Not only should attempts be made to balance loads at sites but also an attempt should be made to ensure that a site does not run out of memory space when other sites have plenty available. So the sizes of segments can be biased upwards proportional to the amount of free memory at their site. This will encourage migration away from sites with little free space. 4) A good part of a computation may consist of repeated calls between the same pair of domains, or, more generally, a repeated sequence of calls. If the domains reside at different sites and all are larger in size than the processor base segment then the processor base segment could continually travel between the sites concerned. Obviously computation would proceed faster if all the domains were at one site. If a 'shadow' stack is kept with the processor base segment it is easy to generate a count of how many consecutive interdomain jumps have been made in the same sequence of calls. If this count is used to bias upwards the size of processor base segment then eventually all the domains involved will come to the same site. In particular domains that call 'tied down' peripheral handler domains will tend to migrate to the site of the handler domain. Of course, if a computation uses two or more peripherals controlled from different sites then the processor base segment, together parameter segments, is doomed to traverse back and forward between sites. This observation lends weight to the desirability of the workstation approach to controlling peripherals (chapter 7). The effects of the first stage calculation can be summarized as follows: It effects at most three sites and it tends to balance the load and free memory of these sites. It tends to aggregate all incarnations of one domain at one site. It tends to localize to one site domains that are used together. Other things being equal, it minimizes the load on the communication subsystem. The second stage calculation: The first stage calculation we have described above only takes into consideration a maximum of three sites, and nominates one of them 'best' site. A site that is completely idle would have no way of breaking into the circle of the elect if only this calculation were used. The criteria we use for accepting or rejecting the entry capability at the 'best' site overcomes this problem. Assuming that the domain is not 'tied down' at its site, the 'best' site kernel scans the table it has of the loads at other sites and if some other site is substantially less busy than itself (and, according to the free space table, has the space to accomodate the domain incarnation) then that site will be nominated as 'best' site. If the kernel does not find a substantially less busy site then it checks to see if its own site has enough space not only for the incoming segments but also for any temporary local segments that have to be created. If it does have the space it accepts the entry capability, requests any external segments to be sent to it, and eventually schedules the domain incarnation ready to run. If the kernel does not have enough space then a second, less critical, scan of the load and free memory tables is made to find a site that does have enough space. If no such site can be found, or the domain is tied down to the present site, then the incarnation is placed in a queue of incarnations waiting for space. It is when the distributed system has sites that have reached this stage that the danger of deadlock becomes real. In the case of an incarnation of a domain that is tied down, the kernel could scan its ready to run queue and invalidate the entry capability of an incarnation of a domain that is not tied down, in the hope that this incarnation will move to another site and so release space for the tied down domain incarnation. The effects of the second stage calculation can be summarized as follows: At low loading of the system it has little effect, there is no point in moving computations to idle sites if they leave an idle site behind. At moderate loading of the system the policy is to try to keep all sites busy. At heavy loading of the system the concern is more with finding space for incarnations. # SECTION 3: REMARKS ON DOMAINS IN DISTRIBUTED SYSTEMS. This chapter concludes the description of kernel/domain model for distributed systems presented in chapter 6. Together these two chapters extend the field of application of domains. Hitherto domain management using capabilities has been centred around single site This is because central tables have been systems. required to implement the capability mechanism. By restricting the sharing of segments and providing a global object management scheme to cover the essential sharing required, we have been able to dispense with central tables and hence distribute domain management. Our main goal in achieving this extention has been to facilitate dynamic and efficient load sharing but our model can equally well be used to provide, in distributed systems, the protection normally associated with domains in single site systems. #### CHAPTER 9 ### DESCRIPTION OF SIMULATION The developers of the DELTA language, a successor to SIMULA 67, say in an introduction to a definition of the language, "Computer simulation has become an important methodological tool in the study of systems. Quite often, the actual simulation model runs on the computer provide useful information. What is nearly always useful, however, is the effort invested in writing the simulation program. This work requires a careful attention to both the main structure of a system and to its details. The result is often an understanding which makes the later computer analysis less important in comparison." [HOLB75]. We have written a simulation of a distributed system. Dur main ourpose in writing it was to make sure that our concept of the requirements for a distributed system was complete. Dur major interest was to learn more of the problems of distributed computing rather than to accurately predict performance. Nevertheless there were two semi-quantitative questions of considerable importance that we wished our simulation to provide guidance upon. These were: - 1) What would be an adequate bandwidth, approximately, to support what could be a considerable movement of segments? - 2) Would increasing the number of sites in the system give close enough to a linear increase in power, or would overheads swamp the modest decrease in response time predicted in chapter 2 (figure 2.9)? But perhaps the question of greatest concern to us was that of stability. We wanted to determine if we would achieve stable load balancing using the various strategies we have outlined for distributed control. The demonstration that stability could be achieved in a simulation would bode well for its achievement in an actual implementation. The system we simulated uses directory updating for global object management and appends status information to each message (see chapter 3). We discuss the results of our simulation in chapter 10. The actual simulation program and some sample outputs are reproduced as appendix A. ## Choice of language: We chose SIMULA 67 [DAHL72] as the language in which to write our simulation program. The CLASS concept of this language allows for the easy and flexible definition of objects in the simulation. The built-in CLASS of Simulation provides facilities for linking objects into lists and primitives for handling the flow of time. These features are expanded upon in a tutorial paper by Ichbiah and Morse [ICHB74]. We assume familiarity with the language in the rest of the chapter. When we came to use SIMULA 67 we found it had a number of drawbacks. The first is that it uses a single precision real variable for representing time. In a computer system's simulation the span of times that are of interest ranges from instruction execution times, of the order of one microsecond, to say a total simulation time of two hours. With 7 digits significance, as for the IBM 360 version of SIMULA, lack of differentiation [HUTC68] of events would occur after the simulated time reached 10 seconds. In fact in our simulation the smallest period of interest was around 100 microseconds and, because of the expense of computer time to run the simulation, its duration (in simulation time) was around 1000 seconds, so we just avoided the problem. Our second problem arose from a language rule that classes can only be used as a prefix at the level at which they are declared (or in the case of system classes at the level enclosed by the simulation block). Declarations of the form Simulation BEGIN Process CLASS communication\_system; • • • • CLASS site; Process CLASS kernel; ...; Process CLASS clock; ...; . . . . END of class site; . . . . END of simulation block; are illegal! All objects that make up a site have to be declared at the outer level, including all objects that are linked into queues inside the kernel. This has produced a large separation in the program between the declaration of objects and their use. The program structure is not clarified by this separation. Another problem was that none of the implementations of SIMULA 67 that we had access to, IBM SIMULA versions 02.03 and 04.00 on IBM 360/65 and IBM 370/168 under DS, and Dec-10 SIMULA KA version 1C, could garbage collect correctly. This meant that the creation of new objects during the simulation had to be severely curtailed so that garbage collection would be invoked infrequently; thus lessening the chance of garbage collection being invoked in a situation that the implementation could not handle. This restriction, while perhaps aiding the run time of the simulation, has led to considerable artificiality in the program. For example, instead of control messages being created when required, acted upon and abandoned (to be garbage collected) instances of every type of control message have to be created at the start of the simulation and the same instance altered for each individual message. The implementations had other faults also and we finally abandoned work with the IBM versions. We should note however the high compatibility between the languages accepted on the various machines. We moved our program from IBM to Dec versions and it immediately compiled. We also performed the reverse move at a later date, and with the assistance of a short conversion program, again achieved immediate compilation. ### The basic structure of the simulation: SIMULA 67 simulations use the Process class to describe entities in the simulation that are active. In our simulation there are six types of process. Each process is activated by some process (except for initiation), performs some actions, which can include the activation of other processes, and then passivates - itself. The activation of a process by another can be specified to take place immediately, or after the actions of the activating process are complete, or with a simulated time delay. Figure 9.1 depicts this simple description. The six types of process are: - Process CLASS kernelc; (lines 573 to 1918 in the program in appendix A). Each kernelc instance simulates the behaviour of a site and its kernel. - 2) Process CLASS clockc; (lines 3112 to 3139). For each site there is a clock 'ts\_clock', which can be set to interrupt the site. - 3) Process CLASS s\_channelc; (lines 2994 to 3029). Each site has one s\_channelc instance to handle the transmission of messages to other sites. - 4) Process CLASS consolec; (lines 3035 to 3094). This class simulates the action of a user, presenting the distributed system with work, waiting for the work to be performed, waiting for a 'thinktime' period and then presenting another request for service from the system. - 5) Process CLASS diskc; (lines 3271 to 3319). There is a instance of this class for every disk in the distributed system being simulated. The function of this class is to define the delays in accessing information on a disk. - 6) Process CLASS disk\_controllerc; (lines 3151 to 3263). There is one instance of this class for every disk. It deals with communication between the disk and Sequencing in a quasi-parallel process Figure 9.1 sites, and does some buffering of requests for use of the disk. #### Segments: The basic entity of the domain oriented system we have described in the previous chapters is the segment. The simulation however uses more basic entities than this. All objects that are to be queued in the system have to be Link CLASS objects. All objects that are transferred between sites, that is inter-kernel control messages and segments, belong to the Link CLASS contents (line 530). The attributes of a contents object are a length, an origin site, a destination site and status information of the origin (for the updating of the destination network status tables described in chapter 3). A segment is one of the subclasses of the contents class (line 546). Additional attributes include site and key to the hash organised segment table at that site. Each of the types of segment in our model are represented as subclasses of the segment class. Thus we have: segmentc CLASS domainc; (line 2061). The extra attributes of this class are an identification number or name (did) and an indication (tied) as to whether or not the domain must remain at one site always. This class also defines a set of kernel calls such as requests for interdomain jumps. domainc CLASS monitore; (line 2161). This class distinguishes the sizes of the two segments that make up the basis of a monitor, c\_size being the size of the code segment and db\_size being the size of the public segment. The two segments are always treated as a single unit in the simulation. monitorc CLASS secretaryc; (line 2172). This class corresponds to monitors with condition queues (chapter7). Its extra attribute is a queue, my\_q, and it provides procedures for 'first in first out' manipulation of the queue. It also provides procedures for the creation of a secretary processor and control procedures for it. segmentc CLASS virtual\_processor; (line 2227). The attributes of this class include information for the kernel, such as priority, a stack of entry capabilities and space for parameters. segmentc CLASS local\_seg; (line 2328). This class includes a procedure for moving local segments from entry capabilities to A\_lists. The handling of local segment capabilities is not as general as the description given in chapter 7, mainly because of difficulties arising from not being able to dynamically create and delete either local segments or entry capabilities. The relationship of the various classes in the simulation is depicted in figure 9.2. #### The action of the kernel: The basic action of the kernel is to examine entries one at a time from the 'ready to run' queue, called driverq in the simulation (line 1623). Its action depends on the type of the entry. When driverq is empty the kernel is idle and so passivates; some other process class object, usually in the communication subsystem, has to activate the kernel again, which is done by calling the procedure switch\_context (line 1528) when it has placed a new entry in driverq. The queue driverq has in fact 4 priority levels; 'high', 'monitor', 'medium' and 'low'. The class definition and associated procedures are given in lines 217 to 284. At each priority level entries are queued first come first served. Entries at the 'high' level pre-empt kernel attention from lower priority levels. After execution of all tasks at the 'high' priority level, execution of the the first entry in the next highest priority, non empty queue takes place. Since all entries to 'monitor', 'medium' and 'low' are the result of executing 'high' priority tasks the effect is that each level pre-empts lower levels. The use of the various levels is as follows: THE CLASS HIERARCHY OF OUR SIMULATION Figure 9.2 - high: All messages requiring kernel attention including putative entry capabilities for domain incarnations, but excluding valid ready to run domain incarnations, are queued at this level. Any entry arriving on this queue pre-empts kernel attention from lower priority levels, by executing the switch\_context procedure if necessary. - monitor: All valid (i.e. ready to run) incarnations of monitors are queued here. Since this is the highest level of valid domain incarnations once an incarnation is at the top of this queue it will remain there until it gives up control to the kernel, ensuring the exclusive access we discussed in chapter 7. for although any high priority message will cause execution of the monitor incarnation to be interrupted, there is no way to put a valid incarnation ahead of the interrupted one in driverq. So when the interruption has been dealt with the original monitor incarnation will be resumed. - medium and low: All other valid domain incarnations are queued at these two levels. When a virtual processor has had a period of service greater than 'longtimeslice' since it last interacted with a console, it is moved from medium priority to low priority. Although we have not used such a category we suspect that in a real system a 'top' priority may be required for initial loading and dealing with catastrophic failures. The kernel contains some general sections of code to assist it in handling the various driverq entries. These sections are: ## Memory management. (lines 640 to 776) The program does not simulate any particular memory management policy. It just keeps count of how much free space there is and increases the simulated time taken to grant space when there is not much free space. The memory management section handles the possible queue of domain incarnations waiting for space. Two queues are kept, one for small requests which are given priority, and one for larger requests. Included also in this section is the procedure 'make\_space' which scans information about domains to delete copies of pure domain code segments when space is scarce. # Segment management. (lines 778 to 846) This section provides procedures for adding, deleting and retrieving segments at a site. A hash function is used on the unique identifiers of segments (key) so that the segment table at each site can be kept reasonably compact. The simulation blurs the distinction between a capability for a segment and the segment itself. A capability contains all the attributes of a segment and thus is analogous to an instance of the class segment, which contains all the attributes of a segment as well. Thus, for example, there are always exactly two references pointing to an instance of a local\_seg. One, stored in an entry capability, represents the capability for the local segment, the other one, stored in a segment table (except when the segment is being moved from site to site), represents the segment itself. # Communications interface. (lines 848 to 941) This section of the kernel interacts with the communication subsystem. When a message arrives the status information it contains about the sender is examined and the message is placed in driverq. In the case of the message being a segment, the segment is registered in the segment table. The kernel places all messages it wants to send to other sites in one of two queues. The higher priority queue is for short control messages, the other is for segments. Each time the s\_channelc process has finished transmitting a message it interrupts the kernel, by placing a message in driver and calling switch\_context. The kernel releases the space the message occupied (except perhaps when the message was a pure domain code segment) and initiates the transmission of another message if there are any to be sent. Broadcasting is performed by placing individual messages for all the other sites in the send queue and transmitting them serially. ## Load monitoring. (lines 943 to 1025) Part of the heuristics for avoiding deadlock (chapter 7) are contained in this section. Its main purpose is to monitor the amount of free memory at all sites, including its own, and maintain a boolean 'overload' which it sets when the free memory in the total system has diminished past a critical amount. The procedure 'ootimum\_site' is used to assist in the second stage 'best' site calculation for domain incarnations. ## Domain management. (lines 1027 to 1526) The various procedures in this section implement the strategies outlined in chapter 8. The other main procedures in the kernel are switch\_context, which we have already described, and execute. The procedure execute (line 1543) simulates the execution of a domain incarnation. Since domain incarnations can be interrupted the simulation of their execution requires some care. Our simulation program allows the action of each domain to be broken into as many as five steps, and associates with each step an execution time. The kernel process passivates itself for the execution time of the step and then 'instantaneously' executes the step. If the action of the step does not result in the termination of the domain incarnation (that is its removal from driverq) the kernel process passivates for the duration of the execution time of the next step after which it "instantaneously" executes that step, and so on. During any period of the kernel being passivated it can be activated by another process executing the switch context procedure. Since the interruption may result in another domain incarnation being placed in driverq at higher priority than the incarnation whose simulated execution was interrupted, the name of the next step and the time remaining until it was due to be executed (runtt) are stored with the entry capability for the domain incarnation. Thus simulated execution of the domain incarnation can take place at any time. ### The entries in driverq: We now describe in more detail what actions the kernel takes for the various sorts of messages it finds in driverq. ### Entry capabilities. (line 1633) The kernel checks to see if the entry capability has been validated. If so, control is passed to the code segment of the domain (simulated by invoking the procedure execute). If the entry capability is not valid the kernel initiates action to make it valid using the procedures in the domain management section. Time slice interrupt. (line 1676) Virtual processors are subject to time slicing. When a timer interrupt occurs the kernel continues with the current domain incarnation (giving it a new quantum of processing time) only if the domain is a monitor or the kernel has no other work to do and the domain has not been reserved for another site. Otherwise the entry capability is invalidated so that the domain incarnation will end up last in the medium or low queue (perhaps at a different site), depending on how much service time the virtual processor has received since it last interacted with a console. ### Message from a console. (line 1705) If the secretary processor for handling console input (see later) is not already scheduled then it is placed in driverq. The message is placed in a special queue for the attention of the secretary processor when its incarnation is run. Request to transfer a domain to another site. (line 1719) The kernel carries out the action described in the section on domain management in chapter 8. If it has the domain, and has not reserved it for another site, it reserves the domain for the requesting site and checks if it can send the domain off immediately. If the domain is already reserved then the request is sent on to the site that has the reservation, otherwise the request is sent to the site supposed by the kernel to have the domain. Arrival of a domain. (line 1750) A domain is placed in drivery when it arrives from another site having been previously requested (except for initial program loading). The kernel places into drivery all entry capabilities that were waiting for the arrival of the domain so that their 'best' site calculation could be performed. It also checks to see if the domain is the last outstanding external segment for any domain incarnation otherwise ready to run. If so, that incarnation is also placed in drivery, at the appropriate priority level. Domain change of site update. (line 1796) The kernel registers the changed site in the information it keeps about every domain. Request for local segments. (line 1801) The kernel prepares to send the segments off immediately. Request for processor base segment and parameters. (line 1814) Again the kernel sends off the required segments immediately. End of message interrupt from s\_channelc. (line 1829) The kernel initiates the transmission of the next message if there are any queued. If the previous message was a segment it frees the space occupied by it. In the case of pure domain code segments a test is carried out to see whether to keep a copy or not. Arrival of processor base or local segment. (line 1853) The arrival is always the result of a previous request, made to another site, that the segment be sent. The domain incarnation to which the segment belongs is determined, and if it is the last segment required for the domain incarnation the domain incarnation is placed in drivers. Hopefully we have built up a picture of how kernels comperate to make the distributed system run. Their chief action is of course to execute domain incarnations but such executions give rise to many different types of messages to be passed between kernels. Kernels deal with incoming messages as fast as they can so that other sites will not be held up unduly. #### Action of domains: Kernels do not provide most of the facilities of an operating system, that is the function of the various domains in the system. In our program we have simulated the action of four areas of an operating system; command analysis, diskhandling, compiling and user program supervision. We have also provided some unspecified domains and monitors that simulate the resource requirements of other operating system facilities. Details of the domains are as follows: ### domainc CLASS type1; (line 2408) This class has no specific purpose. Its possible actions (determined on a probabilistic basis) are to call another domain of this or the type2 class (see below) and to call the diskhandler domain to read a buffer from disk. An incarnation of a domain of type1 class has two local segments, one of which is passed as a parameter to the diskhandler domain. In our simulation we used ten instances of this class of domain intending to represent areas of an operating system that handle various sorts of trivial requests (c.f. the number of domains in the SUE system nucleus (SEVC721, chapter 5). ### monitorc CLASS type2; (line 2493) The function of this class is similar to type1. Instances of this class handle trivial requests that involve the use of system wide tables. Its action is simpler than type1, consisting of processing followed by a return. Each incarnation has one local segment. The simulation program in appendix A has five instances of this class of domain. ### domainc CLASS compiler; (line 2530) The system we simulated is assumed to have two compilers. The compiler class of domain makes substantial demands for processing power and makes large transfers to and from disk. It has two local segments, one of which is used as a buffer for disk transfers. ### domainc CLASS user\_supervisor; (line 2589) This class simulates the 'interpretation' of user programs. We use one instance of this class in our simulation, but multiple instances could be used to simulate different supervisors available to different users. The supervisor domain has three local segments, one for user code, one for data and the third is a disk buffer for reads and writes to disk. The action of a user program is assumed to consist of a cycle of processing followed by disk request. ### secretaryc CLASS command; (line 2886) Each virtual processor has a random number seed associated with it. This seed is used (and updated) by the code of domains when it is desired to simulate different behaviour for different users. The command domain is entered when a request for service is received from a console. It determines, using the random number seed, what domain (from a choice of user-supervisor, 2 compilers or any of the trivial command domains) the virtual processor will enter next. When execution in the chosen domain is complete the virtual processor returns to this domain whence the controlling console is notified that service is finished, and the virtual processor is suspended until another request is received from the console. The secretary processor associated with this domain executes different code from all other virtual processors. Its function is to choose the correct virtual processor, from among those suspended, to respond to a request for service from a console. The kernel at the site that receives messages from consoles (assumed always to be the same site) schedules the command secretary processor for execution on receipt of a console message. Unce it runs, the secretary processor schedules an incarnation of the command domain by the virtual processor associated with the console. The command domain is tied down so that it can communicate with consoles. It does not have any local segments but does, of course, have a public segment. This domain is one of the two types in our simulation that co-operate with the kernels to try to ensure stability and freedom from deadlock in the system. Since all virtual processors pass through this domain, a count is maintained of how many there are active in the total system. If this number exceeds a certain figure or the boolean 'overload' at the local site is set, then only trivial commands are allowed to proceed. The rest are held up until the number of virtual processors is reduced. This scheme is similar to that described by wilkes [WILK73], where processes have to move from a waiting list to an accepted list before they are eligible to be considered for running. Our scheme, in examining the nature of a request for service before placing it in an 'accepted' or 'waiting' state, produces better response time characteristics for requests that are known to be small because they involve specific domains. ### secretaryc CLASS diskhandler; (line 2661) This domain is quite complex. In conjunction with its associated disk\_controllerc process it performs the actions described in chapter 7, in the section on limited capacity controllers. All requests for reads or writes for the disk belonging to the diskhandler domain are programmed as interdomain jumps to the diskhandler domain. In the domain, writes to the disk are dealt with immediately, the descriptor type capability for the segment to be written is placed in a queue (wq) and the return to the calling incarnation is made. If wq is full then the incarnation is suspended instead, on a condition queue, wql or wqh, depending on the priority of the virtual processor. As we empties, by segments being transferred to the disk, entries are removed from weah first, since it has incarnations of medium priority virtual processors, and then from well. The virtual processors are allowed to resume their incarnations in the calling domains. Thus there is limited buffering of disk writes, but a virtual processor cannot fill up the distributed system with segments destined for the disk. Since a virtual processor doing a write is not usually held up, a virtual processor entering the domain to read from disk is normally given priority. As we mentioned in chapter 7, the entry capability for the resumption of the calling domain is prepared so that there will be no delay when the read has been performed. This entry capability is stored in either the rah or ral queues depending on whether priority of the virtual processor is medium or If the boolean 'transfer\_in\_progress' is false then the virtual processor can initiate its own read or write operation. Otherwise this is the function of the secretary processor. Its incarnation of the domain is made ready to run every time the kernel receives a message from the disk\_controllerc process indicating that it has a free buffer (so that a read or write can take place). Actually the form of this message is simply the secretary's entry capability for the domain. The diskhandler domain also contributes to the maintainence of system stability. If the 'overload' boolean at its site is set true then the normal ordering of reads before writes is reversed to free space. Also virtual processors that have low priority (i.e. have been running for a long time since their last console interaction) will be suspended after a write request (in my\_q) until the overload conditon has been overcome, whence they will be released one at a time. We should point out that the fixed number of buffers in the disk controller together with the fixed amount of memory in the system could be a fertile source of deadlocks. One of the segments (with status 'ondisk') of a domain incarnation being resumed after a disk read, occupies a disk buffer. Free space at a site is required before the segment can be transferred to the site, the buffer freed and the domain incarnation permitted to proceed. The incarnations of other virtual processors occupy memory at sites and, if they need to do a disk read or write, require a disk buffer to be free before they can proceed. ### Statistics: SIMULA 67 is well suited for the gathering of relevant statistics in a simulation. The procedures we used are defined in the statistics section of the program (lines 286 to 528). These procedures were designed so that whatever the number of sites, users, disks etc. in a system the program would automatically generate correctly annotated statistics. Most of the last part of the program (line 3321 onwards) is concerned with the setting up of these statistics. An example of the output produced is given at the end of appendix A. The simulation was allowed to run for a simulated time 'settle\_time' after which all the statistic counters and timers were set to zero. Then the simulation period 'sim\_time' when continued for a accumulated statistics were output and the simulation The amount of CPU time used on a Dec-10 KA terminated. system varied between about 10 and 50 minutes per simulation run, depending on how many consoles and how many sites were being simulated. ### Performance parameters: We complete this chapter by summarizing the configuration we simulated and giving figures for the simulated load presented by consoles. The simulated distributed system consists of N sites directly interconnected and, for the transmission of segments, directly connected to the one or several disks in the system. Each site has primary memory only. All consoles (M of them) are controlled from one site and each disk, when there is more than one, is controlled from a separate site. Adams and Millard have published figures for the load presented to EMAS [ADAM75]. They give distributions for the service times required for important classes of work; compilations and the running of compiled programs. We arbitrarily decided that each site in our distributed system would execute programs at one quarter of the speed of the EMAS central processors. So the times we give here are quadruple those given in ADAM75. EMAS has two different compilers in common use so we used two instances of the compiler class in our simulation. The mean time for a compilation is 20 seconds. (The complete histogram of compilation times is defined by the arrays A, cumulative probability, and B, compile time, at line 2580 of the program). The mean execution time for a user program 24 seconds. (The histogram is given by the arrays ueserp, cumulative probability, and usert, execution time, line 161 of the program). In this case we did not quite follow the distribution given by Adams and Millard. Their distribution was biased by a few long execution times and would have required us to cater for executions of up to 480 seconds. Иe imposed a cut off at 180 seconds. The pragmatic reason for this is that 480 seconds is about the duration of a simulation run so that the statistics from a run including such a request would be considerably distorted. But there is also a justification for our action. We believe that performance of a system affects the characteristics of the load offered to it. The person who submits the equivalent 120 second job to EMAS probably runs it at times of slack demand so that a high fraction of total processing power is devoted to the job and the resulting response time is satisfactory. In our distributed system the best that can be done with a 480 second job is to dedicate one site to executing it so that the response time is necessarily much longer than 120 seconds. Users will thus be discouraged from running long jobs. Seventy four percent of all commands issued are of the trivial kind. This high proportion of trivial assertion in EMAS also supports our that requests performance affects the load presented. EMAS responds well to short commands (and our simulation is designed to good response to them also). If everyone had to wait an average of say 40 seconds to find out how logged into the system, or to have the time printed out, then they would not make such requests Adams and Millard do not give distributions for often. trivial command execution times. The strategy we picked the operation of type1 and type2 domains (see above) interdomain call more to exercise the chosen mechanism than reflect reality. A trivial command in our simulation can involve up to 18 interdomain jumps. The execution time of a trivial command averages almost milliseconds and is approximately negative exponentially distributed. The following table gives, for our simulation, the number of each type of console request as a percentage of the total number of requests for service (see lines 2905 to 2909). It also shows how 'useful' physical processor time (i.e. ignoring overheads and idle time) is distributed among the categories. ### Distribution of command types | Туре | relative frequency | % cpu time | |-----------------|--------------------|------------| | Compilations | 9 | 31 | | User executions | 17 | 67 | | Trivial | 74 | 2 | Table 9.1 The overall average time to execute a command is just over 6 seconds. Although the average think time (including console output and input time) is reputed to be 35 seconds on EMAS, which agrees exactly with that reported elsewhere on other interactive systems ISCHE67, ESTR671, we have used a negative exponential think time with a mean of 50 seconds. We wanted to include each interaction with a text editor as a trivial command by itself and so shortened the average think time to compensate for a higher interaction rate for editing. The other timings in the simulation have been arbitrarily chosen. By and large we assumed that the hardware constituting a distributed system would be efficient at performing domain management type tasks. When it came to specifying the other resource requirements of domains, namely the amount of space they require and the number and frequency of disk requests, we had no guidance from published sources. Agrawala and colleagues have recently published a study [AGRA76] correlating cpu demands with memory requirements and I/O to disk (among other factors) but there is no way of deducing from the categorization of jobs (done by cluster analysis) which domains would belong to what category. Each site in the simulation is assumed to have 128,000 bytes of memory, 4,000 bytes of which is occupied by the kernel. This amount of memory at a site could be considered large, but there is no point in simulating the addition of extra sites to a distributed system when the addition of extra memory at each of the existing sites would produce the same results. The size of a processor base segment is made to be 200 bytes. The following table (9.2) lists the size (or range of sizes) in bytes, of incarnations of the various domains (assuming 20 users, as some public segment sizes are determined by the number of users). Sizes of Domain Incarnations Incarnation of ... Bytes type1 1480-3144 type2 1430-3950 command 3122 diskhandler 2760 compiler 17632-17760 user supervisor 13192-36392 Table 9.2 The total size of all domains and processor base segments, before any virtual procesor enters any domain is 52,032 bytes for a twenty user system. If a trivial request goes to the maximum depth of 4 type1 domain calls and performs a disk read at each level it will require about 20,000 bytes of memory in total for all its domain incarnations, and will invoke a kernel to change domains 18 times. Thus even trivial requests can place quite substantial demands on the resources of the simulated distributed system. when it came to disk usage we arbitrarily decided that one in four calls of type1 domains would involve a disk read. For compiling we assumed an average compiling speed of 12 lines a second and, relating this to the size of buffer used, fixed the I/O to disk as a pair of requests, a write followed closely by a read, on average once a second. The assumed distribution of the interval between the write/read pairs is 6 stage Erlang (line 2556). For user programs the mean headway between disk I/O requests, roughly two thirds reads and one third writes, was assumed to be 250 milliseconds. This is twice what the equivalent rate on EMAS is thought to be. This is to compensate for the fact that a user program in a distributed system that had only primary memory, would probably be restricted in size (in the simulation 32,000 bytes is the largest size that user code, data and buffers can occupy) and so would make more transfers to disk than in EMAS, which is a virtual memory system with drum backing store. freely admit that many of our performance We parameters have been rather arbitrarily chosen. in neither the business of detailed workload high resolution performance construction o f nor evaluation. As we have indicated we believe the characteristics of a distributed system will affect the nature of the workload presented to the system. The only way to accurately estimate the workload, as well as determine the number and size of domains, is to actually implement such a system. We feel that the results we present in the next chapter show the practicality of building a domain orientated distributed system that will perform useful work. # CHAPTER 10 RESULTS OF DUR SIMULATION ### General experience: main result of our simulation, a deeper understanding of the requirements of distributed systems has, we hope, been displayed in the earlier chapters. One lesson that was quickly brought home to us by runs of versions of our simulation program was the early necessity to keep all sites as busy as possible. many types of communication subsystem the total bandwidth does not increase as the number of sites in the system goes up, our original 'best' site calculation used minimization of segment transmission between sites as its main criterion, so as to conserve bandwidth. showed that this produced widely simulation runs disparate utilization of processors, with consequent longish queues at the well patronised sites. we quickly introduced a factor in the initial 'best' site calculation so that a site with no work to do would almost always be chosen as 'best' site when the other sites involved had other work. This, of course, accords the ideal of instantaneous jockeying with considerably narrowed the range of physical processor utilizations, as shown, for example, in the 'IDLE TIME' figures in the example outputs at the end of appendix A. Another notion of which we were quickly disabused was that keeping copies of pure code domains would not result There is lot of extra in significant gains. а required to treat pure domains differently from monitors. However, simulations with and without the sharing of pure domain code segments showed substantially decreased loads communication subsystem when the segments were Also since there were only three domains, copied. two compilers and the user supervisor, that received really heavy usage the existence of copies meant that the load could be spread more evenly when there was more than three sites in the network. The accidental retention of some tracing statements in a full simulation run led us to restrict the number times an entry capability could be passed from site to site before actually resulting in a domain incarnation. was of a three site system and the trace simulation output degenerated to a constant pattern towards the simulation. Investigation revealed that the status information that each site held had become that all messages flowed one way around the communications system (see figure 10.1). The information each site had about the succeeding site was well out and indicated, falsely, that the site underutilized. So all requests for a domain incarnation at the site were refused, the succeeding place site was nominated as 'best' site and the request We were aware of the possibility of such a loop Note: Each site's own entry of its own outstanding work is the correct value. This value is appended to all messages sent from the site. OUTSTANDING WORK TABLES IN A 3 SITE SYSTEM GIVING RISE TO A SITUATION WHERE ALL MESSAGES TRAVEL IN ONE DIRECTION Figure 10.1 forming, though we considered it highly unlikely. We assumed that the completion of a domain at a site would probably result in a message being sent in the counter-flow direction. This message would have update information about the sending site so that the loop would What appeared to be happening though, that the kernels were so busy pushing around their rejected domain incarnations that they had no time to do any useful work, and so complete any domain incarnations already running at their sites. The forcing of a site to accept a domain incarnation after it has been through a fixed number of sites has its unfortunate aspects but it does lead to the quick breakdown of any loops. These few examples suffice to show the qualitative benefits of the simulation program. We now go on to present and discuss the semi-quantitative aspects of the simulation. ### Performance measures: The initial simulation runs were to determine suitable values for the various 'twiddle factors' to ensure both system stability and high throughput. That such values, valid for a wide spread of system sizes and loads, did indeed exist is very encouraging. After these tuning runs 3 series of simulation runs were performed. The load characteristics were varied by using a different random number seed for each series. In each series of runs the number of users (consoles), M, was varied from 4 to 24 in steps of 4 and the number of sites, N, was varied from 1 to 6. One disk was simulated in all these runs. The configuration that was simulated is depicted in figure 10.2. In one series of runs the simulation time, T (sim\_time in the program), was 1000 seconds, with a prior settle\_time of 200 seconds. In the other two series the simulation time was 500 seconds, with a settle\_time of 200 seconds in one series and 300 seconds in the other. (The extra 100 seconds did not make any noticeable difference to the results so we assumed that 200 seconds was sufficient to damp down transients caused by there being no work outstanding in the distributed system when simulation started). The chief measurements made during the simulation were response time and service time. Each virtual processor corresponding to a user (i.e. not the secretary processors associated with console serving and disk handling) kept a tally of how much service time it received and how long it was active in the system, the total time [ less all periods of 'thinking time'. These tallies were zeroed at the start of the period [ and were recorded at the end of the period. INITIAL SIMULATED CONFIGURATION Figure 10.2 Thus the statistic total service time (f.S.T) can be defined by $$T.S.T = \sum_{i=1}^{M} \int_{T} s_{i}(t) . dt$$ where $s_i(t) = \begin{cases} 1 & \text{if any domain incarnation of virtual} \\ & \text{processor i is being executed at time t} \\ 0 & \text{otherwise} \end{cases}$ (this is printed as GRAND TOTAL OF SERVICE TIMES in the output example in appendix A). The total response time (T.R.I) is similarly defined by $$T.R.T = \sum_{i}^{M} \int_{T} r_{i}(t).dt$$ where $r_i(t) = \begin{cases} 0 & \text{if the console associated with virtual processor i is in the thinking state} \\ 1 & \text{otherwise} \end{cases}$ (this is printed as GRAND [UTAL OF RESPUNSE TIMES in appendix A). From these two statistics were calculated two more; a response factor, RF, given by $$RF = T.R.T / I.S.I$$ that is the overall ratio of response time to service time, which is also the ratio of the mean response time to mean service time (this is given as PERFORMANCE MEASURE in appendix A). an average processor utilization, U, given by $$U = T.S.T /(N \times T)$$ Since there are overheads associated with kernel operations and secretary processors which do not appear in T.S.T a value of 1 for U is impossible. Table 10.1 gives the overall response factor for the three series of simulations and figure 10.3 depicts this information graphically (T.R.T and T.S.T were both totalled over the 3 runs before their ratio was taken). lable 10.2 gives the overall average useful work done in each (again with the numerator and configuration, U \* N denominator of U being separately totalled first) and figure 10.4 gives a graphical representation of the informatiom. ### RESPONSE FACTUR ### Consoles | Sites | 4 | 8 | 12 | 16 | 20 | 24 | |-------|------|------|------|-------|-------|-------| | 1 | 1.82 | 3.65 | 7.38 | 11.55 | 15.50 | 19.32 | | 5 | 1.45 | 1.80 | 2.77 | 4.34 | 5.51 | 8.23 | | 3 | 1.36 | 1.52 | 1.80 | 2.51 | 3.02 | 4.02 | | 4 | 1.33 | 1.42 | 1.59 | 1.98 | 2.25 | 2.74 | | 5 | 1.33 | 1.39 | 1.50 | 1.74 | 1.95 | 2.29 | | 6 | 1.33 | 1.37 | 1.46 | 1.63 | 1.78 | 2.07 | Table 10.1 # WORK DONE - EQUIVALENT NUMBER OF PROCESSURS ### Consoles | Sites | 4 | 8 | 12 | 16 | 50 | 24 | |-------|------|------|------|------|------|------| | 1 | 0.60 | 0.94 | 0.98 | 0.98 | 0.97 | 0.97 | | 2 | 0.71 | 1.30 | 1.70 | 1.89 | 1.94 | 1.96 | | 3 | 0.73 | 1.39 | 1.99 | 2.48 | 2.68 | 2.85 | | 4 | 0.74 | 1.42 | 2.05 | 2.71 | 3.06 | 3.42 | | 5 | 0.74 | 1.43 | 2.09 | 2.84 | 3.23 | 3.71 | | 6 | 0.74 | 1.44 | 2.11 | 2.91 | 3.35 | 3.85 | Table 10.2 Figure 10.3 # THROUGHPUT (as the fraction of the capacity of one site) AS A FUNCTION OF THE NUMBER OF SITES AND CONSOLES Figure 10.4 The next three tables give some other figures derived from the simulations. Table 10.3 shows the number of bytes transmitted per second over all communication links, including those to disk. Table 10.4 gives the number overall, and per site, of control messages transmitted per second for the various configurations. Table 10.5 gives the utilization of the disk, that is the ratio of the total time it was carrying out a read or write (including seeking) to the overall simulation time. ### BANDWIDTH - Kilobytes per second | | Consoles | | | | | | | |-------|----------|----|----|-----|-----|-----|--| | Sites | 4 | 8 | 12 | 16 | 20 | 24 | | | 1 | 13 | 21 | 23 | 25 | 27 | 26 | | | . 2 | 18 | 33 | 49 | 56 | 59 | 58 | | | 3 | 19 | 42 | 64 | 89 | 95 | 105 | | | 4 | 20 | 44 | 72 | 105 | 125 | 142 | | | 5 | 19 | 43 | 73 | 112 | 137 | 165 | | | 6 | 19 | 41 | 73 | 114 | 139 | 174 | | Table 10.3 2.01 eldeT | 89 | 85 | 05 | 9 <b>۶</b> | 54 | 15 | 9 | | |----------|------------|-----|------------|----|----|-------|--| | 59 | <br>95 | 617 | 55 | 54 | 15 | S | | | 09 | ۶ <u>ς</u> | Ĺħ | ħΣ | ٤٤ | 12 | t7 | | | 05 | 917 | 57 | ٤٤ | ΣŽ | sı | ٤ | | | ħΣ | ħΣ | 32 | 88 | SI | 12 | 2 | | | 81 | 61 | 81 | 11 | 51 | T | t | | | 172 | 50 | 91 | 15 | 8 | 17 | səjil | | | səlosuoj | | | | | | | | # % DISK UTILIZATION ## 4.01 sldeT | | sə į osuoj | | | | | | | |-------|------------|-------|---------------|-------|----------------|-------|--| | 77 | 0.5 | 91 | 12 | 8 | 77 | Sites | | | 8:8 | 8 : 8 | 8:8 | <b>L: L</b> | L: L | t7 <b>:</b> 17 | Ţ | | | 32:16 | 51:15 | ST:05 | 21:52 | 8:71 | 5:6 | S | | | 61:95 | 11:05 | 91:17 | 31:55 | 7:55 | h:II | ٤ | | | 61:11 | 91:59 | h1:15 | 01:17 | 9:42 | 5:11 | ħ | | | 11:98 | 51:07 | 51:59 | 6:57 | 5:72 | 2:11 | S | | | 91:56 | 51:67 | 11:99 | <b>1:5</b> th | 54:45 | 11:5 | 9 | | CONTROL MESSAGES PER SECOND (: PER SITE) Analysis: Nueueing theory considerations [KLEI68, KLEI76] stipulate that the response factor curve must lie above and to the left of two asymptotes; $$RF = 1$$ for M << M\* and $$RF = 1 + (M - M')/N$$ for $M >> M'$ where M' is the saturation number of consoles, given by M'/N = (mean service time + mean think time)/(mean service time) From the figures given in chapter 9, M° is 6\*N. Figure 10.5 is a re-presentation of the data in table 10.1 for N=1, 2 and 3, with the corresponding asymptotes. The correct position and indeed close fitting to the asymptotes gives us confidence that our simulation is not wildly erroneous. The tables and diagrams we have presented show that - \* increasing the number of sites increases the throughput and reduces the response factor for a fixed number of consoles but both effects level off (when there are so many sites that all requests from consoles can be met without any queues forming). - \* increasing the number of consoles without increasing the number of sites leads to greater throughput and a higher response factor, the response factor grows very fast when the throughput approaches the total capacity Figure 10.5 - of the sites and the throughput actually drops slightly when the system is grossly overloaded (presumably because 'wasted' processor power is required to cope with the congestion). - \* for a constant ratio of consoles to sites the number of control messages (indicative of general network management overheads) increases at a greater than linear rate with increasing size of system. - \* at the size of systems considered, control messages (each 32 bytes) account for less than 2% of the total bandwidth. Utherwise use of the available bandwidth grows linearly with increasing size of the system (except, obviously, for the jump from one site to two sites because a system with one site only uses the communication subsystem for accessing the disk). - \* disk usage is correlated with throughput, which is to be expected; roughly 6 seconds of processing gives rise to 1 seconds worth of disk utilization. ### Response factors: The presentation of data in figures 10.1 and 10.2 is too coarse to determine the effect that the number of sites has on the relation between utilization, or throughput, and response factor. Figure 10.7 gives the response factor as a function of average processor utilization for two series of simulation runs with 3, 6 and 9 sites and overall 4, 6 and 8 consoles per site. These simulation runs differed from the previous runs firstly, there was 1 disk per 3 sites for each system and secondly, the period of simulation depended on the number of consoles being simulated (see lines 131 and 158 of the program in appendix A). The reasons tor the differences can be appreciated by referring to figure 10.6 which is an equivalent graph of response versus utilization for 1 and 6 sites, derived from the data from the first series of simulations (augmented runs for the N=1 case to give the low utilization figures). The N=6 curve starts to break away upwards from the N=1 curve when the utilization is only 0.6. This is because with 6 sites the single disk is bottle neck' in the system, rather than the processors, so that the response factor is predicated by the utilization. One disk per three sites is adequate disk capacity so that processor utilization is the the determinant of the response factor in the later series of Also notice that the variance, or spread, simulations. of points from the N=1 curve is large in figure realized, was because the number of console interactions in a fixed period of simulation is when there are few consoles and sites than when there are many consoles and sites, and consequently the variance of estimates made from the results of the interactions must be larger. Hence, to get equal variance independent the number of sites, the simulation should be conducted for the same number of interactions, which is proportional to the number of consoles. Returning to figure 10.7 we see that there is a slight in response time in the region of processor utilization, 0.6 to 0.9, most likely to be operated in. (The cross-over of the N=9 and N=6 curves, when the utilization is 0.9, is a reflection of the proportionally higher overheads in the 9 site system; see later). gain predicted in chapter 2 (cf figure 2.9) occurs even though the simulated service time is not exponentially distributed and the service discipline is not first come first served from a common queue. However this gain will only occur provided that no other resource, such available bandwidth, saturates as the size of distributed system is increased. Given this constraint though, the behaviour of the system is very encouraging. The system builder has some leeway to use strategies that involve overheads at each site that increase with number of sites, and yet still attain approximately linear increases in throughput (for a constant factor) with system expansion. There must be a limit to this process however because the response time ultimately constrained to be at least the service time. ## Bandwidth requirements: As we mentioned earlier the simulated communication subsystem is a directly connected one but each site can only transmit to one other site at a time. Hence the effective bandwidth available in the system increases linearly with the number of sites (including disks). In both the sets of simulations runs described above the capacity of the links from each site was fixed at 1 MHz or, equivalently, 125 Kilobytes per second. Another series of simulations were run for a system of three sites, 18 consoles and one disk, and a system with nine sites, 54 consoles and three disks, when the capacity of the links was varied, in powers of ten, between 0.01 MHz to 10 MHz. Table 10.6 gives figures from this series for the response factor, average throughput per processor (as a fraction of the theoretical maximum) and the bandwidth used, both in absolute terms and as a fraction of the available bandwidth. EFFECTS OF VARYING BANDWIDTH | Link<br>MHz | Sites | Response<br>factor | Processor<br>utilization | Bandwidth<br>used (MHz) | raction of total | |-------------|-------|--------------------|--------------------------|-------------------------|------------------| | 10.0 | 3 | 2.27 | 0.87 | 0.763 | 0.019 | | | 9 | 1./5 | 0.86 | 2.468 | 0.021 | | 1.0 | 3 | 2.66 | 0.83 | 0.793 | 0.198 | | | 9 | 2.26 | 0.79 | 2.494 | 805.0 | | 0.1 | 3 | 36.3 | 0.13 | 0.156 | 0.389 | | <b>V</b> | 9 | 23.7 | 0.16 | 0.583 | 0.486 | | 0.01 | 3 | 338 | 0.02 | 0.016 | 0.396 | | | 9. | 218 | 0.02 | 0.067 | 0.565 | Table 10.6 Table 10.6 shows that 1 MHz available bandwidth per site is adequate but that anything less leads to a severe degradation of response factor and throughput. increase in available bandwidth, above 1 MHz per site, gives a small increase in performance. Note that directly connecting sites is a relatively inefficient way of using bandwidth; at 0.01 Mhz per link intercomputer links in the 9 site system are only 57% utilized even though the communication subsystem is a substantial bottleneck. Indeed the same argument we used for processors in chapter 2, that it is desirable to have 1 server with capacity C rather than N servers with capacity C/N applies to communication subsystems as well. So a bus or loop communication subsystem will have a lower total bandwidth requirement than a directly connected subsystem because of the more efficient utilization of the available bandwidth. #### Extrapolations: Lack of memory space on the computer used to perform the simulations prevented simulating systems with more than 9 sites. We would have liked to increase the number of sites further to determine if there is a practical upper limit to the system size after which the throughput drops or even becomes zero. We suspect that there is such a limit. From the data given in table 10.4 for systems with a ratio of 4 consoles to a site (i.e the diagonal of the table) the best fit quadratic for the number of messages as a function of the number of sites, N, is control messages/sec. = $1.1 N^2 + 10.4 N - 6.1$ For a system of twenty sites and eighty consoles we could predict 650 control messages a second, presenting a communication bandwidth requirement of 20 Kilobytes per second. A one hundred site system with four hundred consoles would require a bandwiath of approximately 400 Kilobytes per second (3.2 MHz) just to the control Each site in such a system would receive a messages. control message on average every 8 milliseconds. gain shown in figure 10.6 for increasing sizes of system cannot offset this squared growth. The overheads associated with dealing with the control messages would substantially reduce the capacity of each site to perform useful work so that saturation, defined above, would occur with fewer consoles and the response factor would be increased. As the throughput falls at each site so, in general, will the number of control messages issued by the site. Thus it is possible that some form of equilibrium state will be reached where the adding of new sites has no effect on the total throughput of the But equally it is possible that distributed system management will take up more and more of the total processing power of the system as sites are added, until eventually the whole system is just dedicated to managing itself and can do no useful work. Examining the total bandwidth used, as presented in table 10.3, we see that after subtracting the load due to control messages (each 32 bytes long) the growth of bandwidth used is reasonably constant at 35 Kilobytes per second for each increment, after the first, of one site and four consoles. Thus the bandwidth used by a system with 20 sites and 80 consoles would be around 700 Kilobytes per second or 5.6 MHz. From table 10.6 a total bandwidth available of 25 MHz would be adequate support this load, probably a lot less would be required if a bus or loop type communication subsystem is used. One hundred sites would use a bandwidth of 35 MHz. designers of Ethernet [METC76] anticipate no problems increasing the present capacity from 3 MHz to 15 MHz, sufficient probably for a 20 site system, but still totally inadequate for a 100 site system. Indeed probably the only way of realizing the required bandwidth for a 100 site system is to directly connect the which requires 4950 links, rather impractical. To our knowledge, in our simulation of up to 9 sites, no domain became a bottleneck. Monitor domains can only be at one site at a time. The larger the system, the greater the risk that one of them will be in continuous demand and so hold back the whole system. Predictions as to when this will occur require figures on the use of individual domains. In a hundred site system no monitor can have an overall average use of more than 1% of processor time if bottlenecks are to be avoided. There is another reason to think that a distributed system of 100 sites would never be implemented along the lines we have described in this thesis. With 400 to 800 active consoles, by the law of large numbers, the load presented to the system would be very smooth. Thus specialization of sites is appropriate. functional Throughout this thesis we have upheld the principle keeping processors general purpose so that they can deal variations in the nature of the with random But when the load is almost deterministic presented. this principle does not apply, provided that the relative numbers of each type of functional unit matches exactly characteristics o f the load. Functional specialization should reduce the management overheads [REYL74]. Αs we showed in chapter 7 functional specialization does slot neatly into our system as the size of the system goes up. So for both technical reasons and theoretical reasons we feel that the ultimate size of a distributed system based on the kernel/domain architecture will be around 20 or so sites. Based on the results we have obtained simulating systems with up to 9 sites, we make the prediction that a system of 20 sites will have 20 times the throughput of a system with 1 site and will be able to maintain the same response time characteristics. ### Summary: The simulation program achieved it goals, as outlined in chapter 9. - \* In writing the program and analysing the results we gained a deeper knowledge of the requirements of distributed computing. - \* The existence of results shows that it is possible to define control strategies that minimize the chances of deadlock, eliminate load levelling thrashing and yet permit useful work to be done. - \* The simulation results show that the bandwidth used by our distributed system is in the order of 3 MHz for the larger systems simulated, which is about that provided in other local networks such as DCS [FARB72c]. Thus the bandwidth requirements are not impossibly high. - \* Within the range of 1 to 9 sites, and over the operational range of processor utilizations, the simulation results show that there is a modest decrease in response time with increasing number of sites. This leads us to predict that expansion will be approximately linear up to about 20 sites. #### CHAPTER 11 #### **EPILOGUE** #### SECTION 1: ACHIEVEMENTS. In this thesis we have presented a philosophy for the software design of a distributed system. By choosing to concentrate on the domain concept, rather than being process orientated, we have arrived at a system with the following properties: - 1) The opportunities for load balancing occur frequently, every time there is an interdomain jump. These load balancing points are optimal in the sense that the minimum possible context is involved. This is because computations are changing their (protection) environment at times of load balancing. - 2) There is no duplication of code except when efficiency considerations dictate that there should be. Since domains are identified with functions, all users of a function will use the same copy of the code for the function when memory space is short. This is in contrast to process orientated systems where either functions have to be statically allocated to sites or all sites have to have the code for all functions. - 3) The domain mechanism neatly handles the control of operating system tables, allowing a single system wide operating system. This frees the maximum amount of primary memory for use by non-operating system programs. - 4) We have incorporated naturally into our system the present state of the art with respect to protection. Domain structured systems have been shown to be more versatile than message passing systems in the kind of protection they can offer. - 5) The philosophy we have adopted leads, in Spier's experience [SPIE74], to better structuring of software and greater reliability. In this thesis we have detailed the special mechanisms required to handle domains in a distributed system. These mechanisms have been incorporated into a simulation program which demonstrated that it is possible to achieve stable operation of a load balancing distributed system. Further, the statistics derived from the simulation show that the design goal we set in chapter 1, a system with low initial cost and nearly constant cost/performance ratio with increasing size, can be achieved. We feel that this thesis raises more questions than it answers. The following is an incomplete list of research topics that we think could be profitably pursued. #### Communication between virtual processors: In chapter 7 we expressed some concern about the efficiency of transferring local segments between two virtual processors. This arose in the context of passing buffers to and from peripheral controllers, but the problem is the same for any form of communication between virtual processors. The processor base segment has to be carried along with the buffer, increasing the load on the communication subsystem. We would like to investigate whether a mechanism similar to ports LBALZ71,AKKO751, used in process orientated systems, can be incorporated into our kernel/domain model. A virtual processor would pass a message, addressed to a port, to its local kernel and the kernels will ensure that the message is delivered to the appropriate place. The use of ports would also affect the concept of secretary processors. The secretary processor would be the sole virtual processor to execute in domains handling peripherals. Of course it may turn out that the management of ports involves more overheads than carrying the processor base segment along with all messages. Research is required to ascertain whether this is so. ## Implementation: In chapter 9 we pointed out that we had no real idea of the characteristics both of user behaviour and program behaviour upon which to base simulation parameters. This, of course, is the lot of all simulators of unbuilt systems, but it is a particularly severe problem for us because our system is quite different from any actually in existence. Building and operating a distributed system would enable research to be carried out in these areas of behaviour. It would also help identify what hardware or firmware features would assist the domain management function. Spier did not publish any performance figures for single site implementation of а kernel/domain architecture. He contented himself with saying operating system is within the realm of the possible, the emergence of next-generation contingent only upon domain-orientated machines' [SPIE74]. hardware Undoubtedly domain management could be very expensive systems with inappropriate hardware. The severity of the problem can only be gauged by implementing the system. Unly then can a realistic determination be made as to whether our system belongs to the class of toy operating systems or is a viable technique for building large systems out of small scale computers. As we have stated before, one very important determinant of viability is the size of domains. Many of the algorithms used in our simulation program could be simply transliterated to a real implementation. (Indeed one of our main reasons for simulating a directly connected system with directory updating, rather than a bus type system with an associative mechanism, is former architecture could be immediately implemented later would require development whereas the communication subsystem). The figures derived from the real implementation could be fed back to the simulation program to validate it and enable it to be used to predict the performance of bigger configurations. #### Programming languages: Buildina actual system would also an evaluating the requirements of a programming language for domain based systems. An easy to use programming language would be of widespread benefit. We have been the implementors of the CAP machine have found it difficult to link segments into domains. Also once language had been developed it would be of assistance in gaining an idea of the natural size for domains (when domains are 'glued together' from some present language code they will probably be made large enough to be efficient irrespective of underlying structure). #### Communication subsystems: The area of computer communications is one where there are still plenty of research problems [OPDE75]. particular interest to us is the design of local would like to know if communication subsystems. Wе transmission schemes such as that employed in Ethernet are stable [KLEI76] and if they can be married with intelligent interface units. Functions of the interface units could include error control, the global object management we have outlined (including ensuring that no messages get lost when a global object changes sites) and intelligence gathering. The intelligence gathering, or eavesdropping, function needs researching to determine effective it is. Some evaluation of its effectiveness could be performed using our simulation program. Our distributed kernel/domain scheme need not be confined to distributed systems. We mentioned in chapter 2 that a scheme devised for a system without shared memory may well be appropriate for a system with shared memory. A knowledge of which segments a computation will access could be used to place the segments so as to reduce or even eliminate memory contention. One kind of architecture that could be investigated is that of PRIME [BASK72, FABR73], but without a supervisory processor. In PRIME memory modules (and backing store units) are switchable between processors. Once switched to a processor, a memory module is accessed privately by that processor. The switching of modules can be considered as a high speed method of transferring segments between processors. The frequency of switching is intended to be very infrequent compared to the frequency of memory accesses. Perhaps the most promising alternative architecture to consider is a system where each processor has its own primary memory but where relatively high performance secondary memory is shared between all processors as a replacement for, or supplement to, the communication subsystem. Fuchel and Heller (FUCH68) have proposed a system of two CDC 6600 computers sharing extended core store (ECS). The ECS was to contain a common job queue and core images of all swopped out jobs. At the end of the power scale, Wensly [WENS75] proposes a system with small computers sharing an electronic disk. and Berenbaum [ARDE75] have given consideration to the type of access circuitry needed for this shared second level of memory. This kind of architecture can be regarded as a multiprocessor system with a cache for each processor. But with the type of system we have proposed, based on domains, there is a massive simplification of the operation of the cache. If the cache holds all the of a domain incarnation then it can be guaranteed a priori that there will not be a consistency be no need to check every cache There will problem. write operation [TANG76] to make sure that the altered word is not also in another cache. It is interesting to note the direction being taken bу the Minerva multiprocessor system [WIDD76]. Cache memory is being introduced to save loading on the shared bus to main The implementors plan to use Concurrent Pascal as their programming language so that a write operation to a shared memory location can be detected at compile time and the consistency problem eased. #### Parting remark: One day soon some microcomputer is going to become the 'de facto' industry standard. Abundant software will be produced for this microcomputer, locking all manufacturers into producing compatible architectures. If these architectures do not have have the capability for easy integration into multiple computer systems then a great and irreversible loss will have occured. But the requirements for multiple computer working have yet to be generally delineated. Our research is a small step towards this goal, a lot more work is needed quickly. ## APPENDIX A # SIMULATION PROGRAM | PROGRAM LISTING | A = 6 | |------------------------|--------| | CROSS REFERENCE TABLE | A = 77 | | SAMPLE OUTPUT LISTINGS | Δ=8-6 | | • | | |---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------| | !Written by: L. Casey Date:Oct 76 Version: PRINT; | 5 | | !The aim of this program is to simulate the operation of; !a network of n computers.; | | | !Each computer has a kernel whose functioning is modelled in;<br>!the class kernelc. The basic operation of the;<br>!kernel is to examine entries in a prioritized queue (driverq);<br>!and take appropriate action (see around line 1350).; | 10 | | !The basic structure of the program is as follows;<br>!lines 41 to 173 declare and define constants and parameters;<br>!of the simulation. Two values, the number of sites and the;<br>!number of consoles, are read as input data.;<br>!lines 180 to 528 declare some primitives for controlling | 15 | | !errors, queues and the gathering of statistics;<br>!lines 530 to 556 declare the basic classes (contents and segments)!<br>!lines 573 to 1918 declare the kernels class, defining the action;<br>!of each computer in the network; | 20<br>); | | !lines 1920 to 2989 declare the classes required for the;<br>!manipulation of domains; | 25 | | !lines 2991 to 3319 declare the other process classes (s_channelc, !consolec,clockc,disk_controllerc and diskc); !from line 3320 onwards is mainly initialization code for the; !running of the simulation; | ; | | | 30 | | | | | lafter the present a speed reference listing is size. | 35 | !After the program a cross reference listing is given.; !The letter D after a line number indicates that the variable is; !declared at that line while M indicates that it occurs more than; !once.; 40 | В | EGIN<br>INTEGER | | | 45 | |---|---------------------------------------------------------|----------------------------------------|--------------------|---------| | | n; | | | ٦. | | | !the number of sites in the | e network (maximum=1 | 28); | | | | INTEGER msize; | !size of primary me | mory at each site; | 5( | | | INTEGER | | | - ( | | | fixed_domains, | !no of operating sy | stem domains; | | | | max_consoles, | | | | | | !no of active consoles atta | | | | | | ipld, | !no of domains exis | | | | | max_disks, | !number of disks (n | ot greater than n) | ; | | | <pre>max_disk_bufs, !number of buffers for each</pre> | a disk controller. | | | | | max_writes_pending, | !a control factor f | or access to disks | : | | | compl, | !no of domains that | | ,<br>60 | | | ddl,ddu,mntrl,mntru,diskl; | | !for naming domain | ns; | | | !diskhandler domains number | red from diskl to di | skl+max_disks-l; | | | | REAL | • | | | | | contextdelay, | | | 65 | | | !the time to preserve conte | ext on accepting an | interrupt: | 0.2 | | | timeslice, | !intervals for user | - · | | | | longtimeslice, | | • | | | | mesdelay; | !the physical delay | /byte in sending; | | | | !a message from one site to | o any other; | | 70 | | | BOOLEAN | 1 6 | | | | | running, | !generally true; | | | | | full_diags,q_trace,mem_trac | se; | | | | | <pre>INTEGER max_local_segs,</pre> | • | | 75 | | | !the number of local segmen | | | | | | max_param_segs, | !number of paramete | - | ed; | | | stack_depth; | !for number of inca | rnations; | | | | INTEGER low, medium, monitor | ,high; | !priorities; | 80 | | | TEXT ARRAY priority_text(1: | | , | - | | | INTEGER null, incore, ondisk | | !status; | | | | INTEGER supern, | !domain number for | user supervisor; | | | | commandn, | | | 0.5 | | | !domain number for interpre | eting commands;<br>!site where all con | 1tth-d | 85 | | | <pre>cnsl_site;<br/>INTEGER size_divider,</pre> | | • | • | | | t_length; | !length of hash tab | | | | | INTEGER load_shed; | · rengen or made car | 20 de cao.: 520e, | | | | !factor deciding when to m | igrate processors; | | 90 | | | INTEGER max_shifts; | | | | | | !another factor for migrati | | ght; | | | | INTEGER chopfactor, chopsize | | | | | | !global constraints on numl | per of active proces | sors; | ۰. | | | INTEGER i_chopf; | core at individual a | itoe. | 95 | | | !desirable limit on process REAL ARRAY userp,usert(1:7) | | iles, | | | | | , , | | | ``` INTEGER wait for d, seek d site, seek choice, spaceclaimed, valid; 100 !constants used in domain_incarnation class; INTEGER random seed; REAL sim_time, settle_time; !duration of simulation; REF (Printfile) results; !file for results of simulation; 105 - Outtext("NUMBER OF SITES*"); Breakoutimage; n:=Inint; mesdelay:=8.0; !microsecs; contextdelay:=200; !microsecs; 110 timeslice:=100000; !half a second; longtimeslice:=500000; running:=TRUE; low:=1; medium:=2; monitor:=3; high:=4; priority_text(low) :- Copy("LOW"); 115 priority_text(medium) :- Copy("MEDIUM"); priority_text(monitor) :- Copy("MONITOR"); priority_text(high) :- Copy("HIGH"); incore:=1;ondisk:=2;trans:=3;desc:=4; Outtext("NUMBER OF CONSOLES*"); Breakoutimage; 120 max consoles:=Inint; max_local_segs:=2; max_param_segs:=1; stack_depth:=5; msize:=128000; !bytes; 125 size_divider:=1024; !bytes; t_{\text{length}}:=20+(\max \text{consoles}*(6+n))//n; supern := 2; commandn := 1; cnsl_site := 1; 130 \max_{\cdot} disks:=1+(n-1)//3; ipld:=2; !two special domains (supern and commandn); comp1:=2; !number of compilers; ddl:=ipld+compl+l; !first ordinary domain; 135 ddu:=dd1+9; !10 typel domains; mntrl:=ddu+l; mntru:=mntrl+4; !5 'ordinary' monitors; diskl:=mntru+l; fixed_domains:=mntru+max_disks; 140 !each disk has its own handler domain; max_disk_bufs:=3; max_writes_pending:=n+l+max_disk_bufs; wait_for d:=1; seek_d_site:=0; 145 seek_choice:=2; !for domain_incarnationc; spaceclaimed:=3; valid:=4; load_shed:=2; max_shifts:=n-1; 150 chopfactor:=n*4; i\_chopf:=(3*chopfactor)//2+1; !allow individual sites 50% more than average load; chopsize:=32000+(\max_{\text{consoles}}/4)*500; ``` ``` 155 !a stab at a formula; random_seed:=787; sim_time := 12000/max_consoles; !simulation over a constant number of interactions; settle_time := 30+2400/max_consoles; 160 !seconds: userp(1):=0; userp(2):=0.37; userp(3):=0.5; userp(4):=0.64; userp(5):=0.86; userp(6):=0.92; userp(7):=1.0; usert(1):=0.5; usert(2):=4; usert(3):=8; usert(4):=20; usert(5):=40; usert(6):=80; usert(7):=180; !last value should be 480; 165 full_diags:=FALSE; mem_trace:=FALSE; q_trace:=FALSE; !a lot of output produced when true; results :- NEW Printfile("RESULT/A:APPEND"); results.Open(Blanks(132)); 175 INSPECT results DO Simulation BEGIN 180 !some utility functions; PROCEDURE ptime; !print the time; BEGIN Outfix(Time, 0, 12); Outtext(Blanks(2)); END; 185 PROCEDURE error(t); VALUE t; TEXT t; BEGIN INSPECT Sysout DO BEGIN 190 Outtext("ERROR OCCURED"); Outimage; !notify terminal user; Outtext(">>>>> ERROR IN MODEL AT TIME"); ptime; Outtext(Blanks(10)); Outtext(t); 195 Outimage; IF NOT full_diags THEN audit; !done automatically otherwise; running:=FALSE; REACTIVATE Main; !continue execution of main block; 200 END; TEXT PROCEDURE fillin(string,i); VALUE string; TEXT string; 205 INTEGER i; BEGIN !returns a text 3 longer than string with i edited into space; TEXT t; t:-Blanks(string.Length+3); !in left most part; 210 t.Sub(string.Length+1,3).Putint(i); ``` ``` !add integer at end; fillin:-t; END: 215 CLASS gheadc; !queueing system with 4 priority levels; BEGIN REF(Head) ARRAY q(low:high); INTEGER i; !work count: 220 REF(Link) PROCEDURE first; BEGIN i:=high; WHILE (IF i < low THEN FALSE ELSE q(i). Empty) DO i:=i-1; IF i < low THEN first: -NONE ELSE first: -q(i). Suc; 225 END; INTEGER PROCEDURE total_entries; BEGIN 230 INTEGER t; t := 0; FOR i:=low STEP 1 UNTIL high DO t:=t+q(i).Cardinal; total_entries:=t; END; 235 INTEGER PROCEDURE b_entries; b entries:=q(low).Cardinal+q(medium).Cardinal: BOOLEAN PROCEDURE gempty; BEGIN !true when nothing in queueing system; i:=low: WHILE (IF i>high THEN FALSE ELSE q(i).Empty) DO i:=i+1; IF i>high THEN qempty:=TRUE; END; 245 FOR i:=low STEP 1 UNTIL high DO q(i):- NEW Head; END of class qheadc; PROCEDURE queue(qhead,entry,priority); REF(qheadc) qhead; REF(Link) entry; INTEGER priority; 250 IF priority GE low AND priority LE high THEN entry.Into(qhead.q(priority)) !insert behind all entries of same priority; ELSE error("WRONG PRIORITY USED IN QUEUE COMMAND"); 255 PROCEDURE q_analysis(qhead, heading, items); VALUE heading; REF(qheadc) qhead; TEXT heading; 260 TEXT PROCEDURE items; !to map ref type variables into descriptive text; REF(Link) ptr; INTEGER i; Outimage; 265 ptime; Outtext(heading); Outtext(" TOTAL NUMBER OF ENTRIES = "); Outint(qhead.total_entries,3); ``` | Outimage; | | |-------------------------------------------------|-----| | IF NOT qhead.qempty THEN | 270 | | FOR i := high STEP -1 UNTIL low DO | | | BEGIN | | | <pre>Outtext(priority_text(i)); Outimage;</pre> | | | <pre>ptr :- qhead.q(i).Suc;</pre> | | | !pick off each member of queue; | 275 | | WHILE ptr =/= NONE DO | | | BEGIN | | | Outtext(items(ptr)); | • | | !returns a text value 12 characters long; | | | ptr:-ptr.Suc; | 280 | | END; | | | Outimage; | • | | END; | | | END of procedure q_analysis; | | | | 285 | ``` Link CLASS statistic(heading); 290 VALUE heading; TEXT heading; VIRTUAL: PROCEDURE clear, print; THIS statistic.Into(statistic_list); REF(Head) statistic_list; 295 REF(Head) grand_t_list; statistic CLASS groupheading; !this helps format output; BEGIN 300 PROCEDURE clear; ; PROCEDURE print; BEGIN Outimage; Outtext(heading); 305 Outimage; END; END of class groupheading; statistic CLASS counter; 310 BEGIN INTEGER count; . !counts occurences; PROCEDURE clear; count:=0; 315 PROCEDURE print; BEGIN Outtext(" NUMBER OF "); Outtext(heading); Outint(count, IF count<1000 THEN 4 ELSE 320 IF count<10000000 THEN 8 ELSE 12); END; PROCEDURE incr; 325 count:=count+1; PROCEDURE add(number); INTEGER number; count:=count+number; 330 END of class counter; statistic CLASS timer(master); REF(grand_total) master; !this class is for accumulating times of operations; 335 !the timer is 'turned on' by procedure start and; !'turned off' by procedure stop; !the final value is added into master; BEGIN 340 REAL start_time, total; BOOLEAN keeping; !true when in action; ``` ``` PROCEDURE start; IF NOT keeping THEN BEGIN 345 !multiple calls o.k.; keeping:=TRUE; start_time:=Time; END; 350. REAL PROCEDURE stop; !in simula can call without using returned value; IF keeping THEN BEGIN !multiple calls o.k.; total:=total+(Time-start_time); keeping:=FALSE; 355 stop:=Time-start_time; END; PROCEDURE clear; BEGIN 360 total:=0; IF keeping THEN start_time:=Time; !reset.and start timing from now; END; 365 .PROCEDURE print; BEGIN REAL t; Outtext(" TOTAL "); Outtext (heading); t:=(total+(IF keeping THEN Time-start_time ELSE 0))*&-6; Outfix(t,1,7); !printing in seconds; IF master=/=NONE THEN master.add(t); !update grand total; END; 375 keeping:=FALSE; total:=0; !default values anyway; END of class timer; 380 statistic CLASS time_average; !for non-negative numbers; BEGIN REAL initial_time,start_time,total; INTEGER val, max; 385 PROCEDURE change value(level); INTEGER level; BEGIN total:=total+val*(Time-start_time); 390 val:=level; IF val>max THEN max := val; start_time:=Time; END; 395 PROCEDURE clear; BEGIN total:=0; max:=val; initial_time:=start_time:=Time; ``` ``` 400 END; PROCEDURE print; BEGIN Outtext(" AVERAGE "); Outtext(heading); Outfix(IF Time-initial_time>0 THEN 405 (total+val*(Time-start_time))/(Time-initial_time) ELSE 0,0,9); Outtext(" MAXIMUM"); Outint(max,8); END; 410 END of class time_average; statistic CLASS grand_total; 415 BEGIN REAL total; PROCEDURE clear; total:=0; PROCEDURE print; 420 BEGIN Outtext("GRAND TOTAL OF "); Outtext(heading); Outfix(total, 0, 7); Outimage; 425 END: PROCEDURE add(t); REAL t; total:=total+t; 430 THIS grand_total.Into(grand_t_list); !overrides statistic_list; END of class grand_total; 435 statistic CLASS regression(heading2); VALUE heading2; TEXT heading2; BEGIN 440 INTEGER n; REAL sx,sy,sx2,sy2,sxy; PROCEDURE data(x,y); REAL x,y; 445 BEGIN n:=n+1; sx:=sx+x; sy:=sy+y; sx2:=sx2+x*x; sy2:=sy2+y*y; sxy:=sxy+x*y; END; 450 PROCEDURE clear; BEGIN n := 0: sx:=sy:=sx2:=sy2:=sxy:=0; END; 455 ``` ``` PROCEDURE print; BEGIN REAL a0, a1, d, sd, r2; Outimage; 460 Outtext("REGRESSION ANALYSIS OF "); Outtext(heading); Outtext(" VERSUS "); Outtext(heading2); Outimage; IF n>5 THEN BEGIN 465 !convert data to seconds; sx:=sx*\&-6; sy:=sy*\&-6; sx2:=sx2*\&-12; sy2:=sy2*\&-12; sxy:=sxy*\&-12; d:=n*sx2-sx*sx; al:=(n*sxy-sx*sy)/d; a0:=(sy*sx2-sx*sxy)/d; 470 sd:=Sqrt((sy2-a0*sy-a1*sxy)/(n-2)); !standard deviation of y; r2:=(n*sxy-sx*sy)**2/(d*(n*sy2-sy*sy)); Outtext("NUMBER OF DATA POINTS"); Outint(n,4); Outimage; Outtext("MEAN OF ");Outtext(heading); Outfix(sx/n,1,7); Outtext(" MEAN OF "); Outtext(heading2); Outfix(sy/n,1,7); Outtext(" RESIDUAL STANDARD DEVIATION"); Outfix(sd,2,6); Outimage; Outtext("ESTIMATE OF REGRESSION COEFFICIENT"); 480 Outfix(a1, 2, 7); Outtext(" INTERCEPT"); Outfix(a0,2,7); Outtext(" STANDARD DEVIATION OF REGRESSION COEFFICIENT"); !has a students t distribution with n-2 degrees of freedom; Outfix(n*sd/Sqrt((n-2)*d),2,6); 485 Outtext("CORRELATION COEFFICIIENT"); Outfix(Sqrt(r2),3,5); END ELSE Outtext("INSUFFICIENT DATA"); Outimage; 490 . END of procedure print; END of class regression; PROCEDURE outputstatistics; 495 BEGIN REF(statistic) ptr; ptr:-statistic_list.Suc QUA statistic; WHILE ptr =/= NONE DO 500 !call virtual procedure; ptr.print; ptr :- ptr.Suc; END; Outimage; Eject(Line+3); 505 ptr:-grand_t_list.Suc QUA statistic; WHILE ptr=/=NONE DO BEGIN ptr.print; ptr:-ptr.Suc; 510 END; PROCEDURE clearstatistics; BEGIN ``` ``` REF(statistic) ptr; ptr:-statistic_list.Suc QUA statistic; WHILE ptr =/= NONE DO BEGIN ptr.clear; ptr:-ptr.Suc; END; ptr:-grand_t_list.Suc QUA statistic; WHILE ptr =/= NONE DO BEGIN ptr.clear; ptr:-ptr.Suc; END; END; 525 ``` !\*\*\*\*\*\*\*\*\*\*\*end of statistics section\*\*\*\*\*\*\*\*\*\*\*; | Link CLASS contentc; VIRTUAL: TEXT PROCEDURE dump; | 530 | |-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----| | BEGIN INTEGER size; !in bytes; INTEGER orgn,dest; !for use only when being transfer between sites by; !communication sub_system; | 535 | | INTEGER mem,qf; !used for kernel to kernel updating; TEXT PROCEDURE dump; !for diagnostics; dump:-Copy("* * * * * * "); !always 12 characters; | 540 | | END of class contentc; | | | <pre>contentc CLASS segmentc(site);</pre> | 545 | | INTEGER site; !where segment resides; | | | INTEGER key; !for segment hash table at site; INTEGER default, status; !take values of null, incore, ondisk, trans; | 550 | | <pre>INNER; IF status=incore AND key&gt;fixed_domains THEN INSPECT k(site) add_seg(THIS segmentc);</pre> | | | !after key has been set;<br>END; | 555 | | <pre>REF(kernelc) ARRAY k(l:n);</pre> | | | REF(grand_total) usage, !for total service time of system; total_response; !for total of all response times; REF(counter) xfered_domains,xfered_processors, !counting how many domains and processors shift site; | 560 | | <pre>xfered_locals, new_incarnations,</pre> | 565 | | migrations, short_commands, over2, over5, | | | !for analysing response times;<br>chopcount, spacecount; !for counting blocked processors;<br>REF(regression) non_trivial;<br>!for response times to substantial commands; | 570 | ``` Process CLASS kernelc(id); INTEGER id; 575 BEGIN REF(qheadc) driverq, !all ready to run tasks held in it; spaceq; !for incarnations waiting only for primary memory space; REF(domain_incarnationc) cu, !pointer to current domain incarnation; 580, !pointer to process handling disk; d_secretary, !ditto for consoles; c_secretary; BOOLEAN maskf, 585 !true when process switching is not permitted; !raised when an interrupt has caused the kernel to switch task; REF(clockc) ts_clock; 590 INTEGER mfree, !size of.current free primary memory at this site; copyspace; !amount of memory used holding code copies; 595 BOOLEAN spaceqempty, !true when no one at this site is waiting for space; !(=spaceq.qempty); deadlock_warning; !true when printed a warning about possible deadlock; 600 REF(s_channelc) s_channel; !for communicating with other sites; REF(timer) idle_timer; !for collecting statistics; 605 REF(time_average) memory_use; REF(contentc) ARRAY space_situation(1:n); PROCEDURE initialization; BEGIN driverq :- NEW qheadc; !set up task queue; spaceq :- NEW qheadc; !set up blocked on memory space queue; spaceqempty:=TRUE; iflag := FALSE; maskf := TRUE; 615 s_channel:-NEW s_channelc(id); cq:-NEW Head; sq:-NEW Head; !queues for messages being sent; 620 ts_clock :- NEW clockc(id); idle_timer :- NEW timer("IDLE TIME", NONE); memory_use:-NEW time_average("MEMORY USE"); mfree:=msize-4000; !4000 bytes is assumed size of the kernel code; 625 m_max:=m_min:=id; memory_use.change_value(msize-mfree); FOR w:=1 STEP 1 UNTIL n DO m_use(w):=mfree; !first estimate; FOR w:=1 STEP 1 UNTIL fixed_domains DO ``` ``` dmn_info(w):-NEW dmn_infoc; !for handling information about domains; FOR w:=1 STEP 1 UNTIL n DO BEGIN space_situation(w):-NEW contentc; !for warning other kernels that near deadlock; !or that have backed of again; space_situation(w).size:=32; END; END; ``` ``` !!!!!!!!!!!!!!!!!!!!!!!!!!!! memory management !!!!!!!!!!!!!!!!!; ! routines to be used by the kernel only ! contains some assumed timings ! memory management policy is not actually simulated, !; ! just arithmetic count kept of free memory. PROCEDURE claim(size, success); NAME success: BOOLEAN success; INTEGER size: !of block of memory required; 650 BEGIN Hold(200+(2000*size/(size+mfree))); !reflects the assumption that as; !space gets tighter more time is required to find free space; IF spaceqempty THEN BEGIN 655 WHILE (IF size GE mfree THEN make_space ELSE FALSE) DO; END; !delete enough code copies to give space if possible; IF size < mfree THEN 660 BEGIN mfree:=mfree-size; !mfree always greater than 0; register m use(id,mfree+copyspace); !alter status information of site; 665 memory_use.change_value(msize-mfree); !statistic; success:=TRUE; IF mem trace THEN BEGIN Outint(msize-mfree, 10); Outchar('>'); Outint(id,1); 670 · END; END ELSE success:=FALSE; END of procedure claim; 675 PROCEDURE q4space(inc); REF(domain_incarnationc) inc; BEGIN 680 !assume that claim has been called immediately before; !i.e. do not check if really has to queue; spacegempty:=FALSE; overload:=TRUE; queue(spaceq,inc, IF inc.extra_space>size_divider THEN 685 low ELSE medium); !small requests have priority over large ones; IF mfree>size_divider THEN BEGIN inc.extra_space:=inc.extra_space-(mfree-size_divider); claim(mfree-size_divider,running); !stake claim to available space; 690 END; Hold(2000); !to sort things out; IF full_diags THEN BEGIN ptime; Outtext(inc.dump);Outtext(" IN SPACEQ AT SITE"); Outint(id,3); Outimage; 695 spacecount.incr; !statistic; ``` ``` 700 PROCEDURE release(size); INTEGER size; !giving back a block of memory; BEGIN REF(domain_incarnationc) sr; BOOLEAN more; 705 Hold(50); mfree:=mfree+size; register_m_use(id,mfree+copyspace); memory_use.change_value(msize-mfree); IF mem_trace THEN BEGIN 710 Outint(msize-mfree, 10); Outchar('<'); Outint(id,1); !diagnostic message; END; IF NOT spaceqempty THEN BEGIN 715 sr:-spaceq.first; more:=TRUE; WHILE sr=/=NONE AND more DO BEGIN : !see if can run incarnation waiting for space; 720 claim(sr.extra_space,more); IF more THEN BEGIN sr.stage:=spaceclaimed; queue(driverq, sr, high); !place freed entry capability back in driverq; 725 sr:-spaceq.first; IF deadlock_warning THEN BEGIN ptime; Outtext(fillin(" DEADLOCK AVERTED AT SITE",id)); !because removed something from spaceq; Outimage; deadlock_warning:=FALSE; 730 END; END ELSE IF mfree > size_divider THEN sr.extra_space := sr.extra_space -(mfree-size_divider); claim(mfree-size_divider,running); !try to keep size-divider of memory; !to be available for small requests; END; 740 END: IF sr==NONE THEN spaceqempty:=TRUE; END of procedure release; 745 BOOLEAN PROCEDURE make_space; IF copyspace>0 THEN BEGIN 750 !each site can keep copies of shared re-entrant code; !the least recently used is deleted; !(only done when spaceq empty); INTEGER i,j; ``` ``` REAL 1ru; 755 Hold(400); 1ru:=Time; FOR i:=1 STEP 1 UNTIL fixed_domains DO IF dmn_info(i).copy THEN BEGIN IF dmn_info(i).work.Empty AND dmn_info(i).external_segs.Empty 760 AND NOT dmn_info(i).going THEN BEGIN IF 1ru > dmn_info(i).lasttime THEN BEGIN lru:=dmn_info(i).lasttime; 765 END; END; END; IF j>0 THEN BEGIN !found a segment to delete; delete_domain_copy(j); 770 make_space:=TRUE; END of make_space; 775 ``` ``` !!!!!!!!!!!!!!!!!!!!segment management!!!!!!!!!!!!!!!!!!!!!! 780 REF (segmentc) ARRAY seg_table(0:t_length-1); INTEGER ARRAY st(0:t_length-1); INTEGER PROCEDURE hash(key); 785. INTEGER key; hash:=2*Nod(key,t_length//2)+(IF key>16384 THEN 1 ELSE 0); !small numbers will predominate; INTEGER PROCEDURE add(key); 790 INTEGER key; BEGIN INTEGER hk,i; hk:=hash(key); 795 IF st(hk) NE O THEN BEGIN !if first slot not free then search table; FOR hk:=Mod(hk+1,t length) WHILE i NE hk AND st(hk) NE O IF i=hk THEN error (fillin("HASH TABLE FULL AT SITE",id)); END; st(hk):=key; add:=hk; 805 END; INTEGER PROCEDURE retrieve(key); INTEGER key; BEGIN INTEGER hk,i; 810 hk:=hash(key); IF st(hk) NE key THEN BEGIN i:=hk; FOR hk:=Mod(hk+1,t_length) WHILE i NE hk AND st(hk) NE key DO: IF i=hk THEN error ("ITEM NOT FOUND IN HASH TABLE"); IF seg_table(hk) == NONE THEN error("BAD SEGMENT MANAGEMENT"); retrieve:=hk; END; PROCEDURE add_seg(s); 825 REF (segmentc) s; BEGIN seg_table(add(s.key)):-s; s.status:=incore; s.site:=id; 830 END; PROCEDURE delete_seg(s); REF (segmentc) s; BEGIN ``` ``` 850 !Communication interface - receiving messages; !Reception of messages takes place in three stages:-; !1) The message arrives - call on procedure int.; !2) The message is stored and the kernel notified by placing; !an entry in driverq - call on queue.; 855 13) When drivery entry is examined action is taken on entry.; PROCEDURE int(m); REF(contentc) m; 860 BECIN IF NOT m IS contents THEN BEGIN !not an empty message; IF m IN segmentc THEN BEGIN IF m QUA segmentc.key LE fixed_domains THEN 865 dmn_info(m QUA segmentc.key).d:-m QUA domainc !domain kept separate from other segments; ELSE add_seg(m QUA segmentc); !it is assumed that space has already been claimed; queue(driverq,m,high); 870 END ELSE IF m IS domain_incarnationc THEN BEGIN IF m QUA domain_incarnationc.stage=valid THEN queue(driverq,m,monitor) ELSE !unless it is a secretary being used as an interrupt; !a domain incarnation can not be valid at this stage; BEGIN queue(driverq,m,high); qfs(id):=qfs(id)+l; 880 !more work at this site; END; END ELSE queue(driverq,m,high); !other message types; switch_context; !notify kernel; 885 END; IF m.orgn LE n AND m.orgn > 0 THEN BEGIN register_m_use(m.orgn,m.mem); !update memory utilization table; qfs(m.orgn):=m.qf; !and size of queues; 890 END; END; !communications interface - sending messages; REF(Head) cq, !for high priority control messages; sq; !for segments; BOOLEAN channel_busy; PROCEDURE send_message(dest,contents); INTEGER dest; REF(contentc) contents; 900 IF dest NE id THEN BEGIN contents.orgn:=id; contents.dest:=dest; ``` !!!!!!!!!!!!!! communications section !!!!!!!!!!!!!!!!!!!!!; ``` IF channel_busy THEN 905 contents.Into(IF contents IN segmente THEN sq ELSE cq) ELSE signal_channel(contents); !wait if busy else send message straight away; END ELSE !short circuit; BEGIN 910 contents.orgn:=id; queue(driverq,contents,high); !do not send secretaries/interrupts to oneself; END of send_message; 915 PROCEDURE broadcast(contents); !to all other kernels; . !must have a different object to go to each site; REF(contentc)ARRAY contents; BEGIN 920 INTEGER i; FOR i:= 1 STEP 1 UNTIL n DO IF i NE id THEN send_message(i,contents(i)); END of broadcast; 925 PROCEDURE signal_channel(contents); REF(contentc) contents; BEGIN channel_busy:=TRUE; !channel deals with one message at a time; 930 contents.mem:=m_use(id); IF contents IS domain_incarnationc THEN qfs(id):=qfs(id)-1; !if monitors with condition queues moved sites; !then this would have to be altered; contents.qf:=qfs(id); 935 !information for receiving kernel; !if in cq or sq; contents.Out; s'channel.initiate(contents); END of signal_channel; 940 !end of communications interface; ``` ``` !****************** load monitoring ********* 945 BOOLEAN overload; !If kernel detects that no site has chopsize of free memory; !or that some site (probably) has entries in its spaceq; !i.e. when its free memory is less than size_divider; !then overload is set true.; !Overload is used by secretaries to modify their behaviour.; INTEGER ARRAY m_use,qfs(1:n); !tables of (supposed) utilization of memory and number of; !domain incarnations at each site; 955 !sites with most and least free memory; INTEGER m_max,m_min; PROCEDURE register_m_use(site,mem); !the amount of free memory at the site; INTEGER site, mem; BEGIN BOOLEAN sort_required; INTEGER j; 960 IF n > 1 THEN BEGIN IF site NE m_max AND site NE m_min THEN 965 IF mem>m_use(m_max) THEN m_max:=site ELSE IF mem<m_use(m_min) THEN m_min:=site;</pre> END sort required:=(site=m max AND mem<m_use(m_max)) OR (site=m_min AND mem>m_use(m_min)); 970 m_use(site):=mem; IF sort_required THEN BEGIN 975 m_max:=m_min:=l; *FOR j:=2 STEP 2 UNTIL n DO !never sort required when n=1; IF m_use(j)>m_use(m_max) THEN m_max:=j ELSE IF m_use(j) < m_use(m_min) THEN m_min:=j;</pre> 980 END; IF m_use(m_max) < chopsize OR m_use(m_min) LE size_divider THEN BEGIN IF site=id AND NOT overload THEN 985 broadcast(space_situation); !this site has been cause of pushing network into overload; !so it notifies the other sites; overload:=TRUE; END ELSE 990 BEGIN IF site=id AND overload THEN broadcast(space_situation); !first site out of overload - tell others; overload:=FALSE; 995 END; END of register_m_use; ``` ``` INTEGER PROCEDURE optimum_site(size,qf_min,qf_max); 1000 INTEGER size,qf_min,qf_max; !Returns the identity of the site with minimum current work; !load (between qf_min and qf_max-1) and free space greater; !than size. Where there is more than one site at the level the; !one with the most space is chosen.; 1005 !If there are no sites satisfying the conditions returns zero.; IF m_use(m_max)>size THEN !worth looking; BEGIN 1010 INTEGER i,j,k; k:=qf_min-1; FOR k:=k+1 WHILE k<qf_max AND j=0 DO FOR i:=1 STEP 1 UNTIL n DO IF qfs(i)=k THEN 1015 BEGIN IF m_use(i) GE size THEN BEGIN j:=i; size:=m_use(i); 1020 END; END; optimum_site:=j; END of optimum_site; !************ end of load monitoring *********; ``` ``` !!!!!!!!!!!!!!!!!!!domain management!!!!!!!!!!!!!!!!!; 1030 REF(dmn_infoc)ARRAY dmn_info(1:fixed_domains); BOOLEAN PROCEDURE validated(dmn_rqst); REF(domain_incarnationc) dmn_rqst; 1035 !this procedure handles most of the stages of transferring; !a processor to a new domain; !it checks if the entry capability - dmn_rqst - is valid; !if not it takes steps to make it valid; 1040 IF dmn rqst.stage=valid THEN validated:=TRUE !ready to run; ELSE BEGIN 1045 Hold(200); !calculation overhead; IF dmn_rqst.stagc=seek_d_site OR dmn_rqst.stage=wait_for_d THEN INSPECT dmn info(dmn rqst.did) DO 1050 !must have entry capability at the site of domain before; !can work on it; IF NOT (here OR coming OR (copy AND NOT overload)) THEN send message(d loc,dmn rqst) ELSE do_domain_calculation(dmn_rqst); 1055 END; IF dmn_rqst.stage=seek_choice THEN BĘGIN IF dmn_rqst.choice NE id THEN !at wrong site; 1060 send_message(dmn_rqst.choice,dmn_rqst) ELSE examine_choice(dmn_rqst); END; !dont set validated so that incarnation goes to end of queue; IF dmn_rqst.stage=spaceclaimed THEN bring_together(dmn_rqst); END of procedure validated; 1070 REAL PROCEDURE cost_formula(site,size); INTEGER site, size; !attempt to give a factor corresponding to congestion; BEGIN 1075 REAL d; d:=qfs(site); IF d=0 THEN d:=0.01; !no work at site; cost_formula:=size*(m use(site)/(d*(msize-m use(site)))); END; 1080 PROCEDURE do_domain_calculation(dmn_rqst); REF(domain_incarnationc) dmn_rqst; ``` ``` !this procedure calculates the 'best' site for the domain; !incarnation to take place; 1085 INSPECT dmn_rqst DO INSPECT dmn_info(did) DO BEGIN INTEGER big_d_size,big_p_size; REAL d_cost,l_cost,p_cost; 1090 INTEGER i; IF coming THEN BEGIN stage:=wait_for_d; !note that has waited; dmn_rqst.Into(rqst_list); 1095 END ELSE BEGIN !first sort out where all the segments are; 1100 l_site:=0; !until determined that local segments exist; total_size:=1_size:=0; d site:=id; d_size:=dmn_info(did).d.size; 1105 big_d_size:=IF d IN monitorc THEN d_size*(l+work.Cardinal+external_segs.Cardinal) ELSE d_size; !try to form a clumping of virtual processors using; !particular monitors; 1110 INSPECT processor DO BEGIN p_size:=size; FOR i:=1 STEP 1 UNTIL max_param_segs DO 1115 IF params(i).status=incore THEN p_size:=p_size+params(i).size ELSE IF params(i).status=trans OR params(i).status=ondisk THEN total_size:=total_size+params(i).size; p_site:=site; 1120 big p size:=p size*sameness; !an agregating factor; END; total_size:=total_size+p_size; !so far size of processor and all parameter segments; 1125 !assume all local segments at same site; FOR i:=1 STEP 1 UNTIL max_local_segs DO IF locals(i).status=incore THEN BEGIN 1130 1_site:=locals(i).site; 1_size:=l_size+locals(i).size; END ELSE IF locals(i).status = trans THEN !to be created; 1135 total_size:=total_size+locals(i).size; IF l_site NE O THEN !some local segments involved; 1140 total_size:=total_size+l_size; ``` ``` !now choose site domain incarnation is to take place; 1145 IF d.tied NE O THEN BEGIN !domain cannot move; choice:=id; stage:=seek_choice; 1150 ELSE BEGIN d_cost:=cost_formula(id,big_d_size+ (IF p_site=id THEN big_p_size ELSE 0)+ (IF 1_site=id THEN 1_size ELSE 0)); IF p_site NE id THEN 1155 p_cost:=cost_formula(p_site,big_p_size+ (IF l_site=p_site THEN l_size ELSE 0)); IF 1_site NE O AND 1_site NE id AND 1_site NE p_site THEN 1_cost:=cost_formula(l_site,l_size); choice:= IF d_cost GE p_cost AND d_cost GE l_cost THEN id ELSE IF p_cost GE l_cost THEN p_site ELSE l_site; !now check that choice is o.k.; 1165 !first check that if domain is going to move; !from this site that it is not already promised; !elsewhere or only a copy exists here; IF choice NE id THEN 1170 BEGIN IF next_site NE 0 THEN send_message(next_site,dmn_rqst) ELSE 1175 IF copy THEN send_message(d_loc,dmn_rqst) ELSE !no objections to domain moving; stage:=seek_choice; 1180 END ELSE BEGIN !this site has been chosen; !if a monitor that has been promised to; !another site is involved, the incarnation will; 1185 !only take place if !1) the incarnation was waiting before the monitor arrived at this site; (stage = wait_for_d); !or; 1190 !2) all required segments are at this site; and other incarnations have outstanding; requests for segments from other sites; IF next_site NE 0 AND stage NE wait_for_d THEN 1195 BEGIN IF external_seg.Empty OR p_site NE id OR ``` ``` NOT (l_site=0 OR l_site=id) THEN send_message(next_site,dmn_rqst) 1200 ELSE stage:=seek_choice END ELSE stage:=seek_choice; !no objection to its staying; 1205. END; END: END; END of procedure do domain calculation; 1210 PROCEDURE examine_choice(dmn_rqst); REF(domain_incarnationc) dmn_rqst; INSPECT dmn_rqst DO 1215 BEGIN BOOLEAN spacefound, !true if this site has enough space for incarnation; tied. !true if domain tied down here; !set if incarnation sent elsewhere; gone; 1220 INTEGER opt_site,i; PROCEDURE send off; BEGIN choice:=opt_site; send_message(opt_site,dmn_rqst); 1225 gone:=TRUE; shifts:=shifts+1; migrations.incr; END; 1230 tied:=IF dmn_info(did).here THEN dmn_info(did).d.tied NE 0 ELSE FALSE; !first see if some other site is under_utilized while this; !site is overbusy; 1235 IF NOT(tied OR shifts>max_shifts OR (overload AND dmn_info(did).here AND shifts>0)) THEN BEGIN opt_site:= optimum_site(total_size+d_size,0,qfs(id)//load_shed); 1240 IF opt_site NE O THEN send_off; !substantially less busy; END; 1245 IF NOT gone THEN !now claim the extra space required and make up lists; !for requesting segments; processor.Into(dmn_info(did).work); 1250 !mark domain as used; IF NOT (dmn_info(did).coming OR dmn_info(did).here OR dmn_info(did).copy) THEN extra_space:=d size ELSE extra space:=0; ``` ``` !it is possible that domain is no longer at d_site; 1255 extra space:=extra_space+total_size - (IF p_site=id THEN p_size ELSE 0) - (IF 1_site=id THEN 1_size ELSE 0); IF extra_space>0 THEN 1260 claim(extra_space, spacefound) ELSE spacefound:=TRUE; IF NOT(spacefound OR tied) THEN BEGIN !see if another site is suitable; 1265 IF shifts LE (IF dmn info(did) here AND overload THEN O ELSE max_shifts) THEN BEGIN opt_site:=optimum_site (total_size+d_size,qfs(id)//load_shed,i_chopf); 1270 IF opt_site NE id AND opt_site NE O THEN BEGIN send_off; processor.Out; !reverse marking of domain; END; 1275 END; END; IF NOT gone THEN INSPECT dmn_info(did) DO 1280 BEGIN !sort out domain whereabouts; count:=0; IF NOT (coming OR here OR copy) THEN BEGIN count:=1; !keep count of segments required from other sites; 1285 processor.d_transfer.did:=did; processor.d_transfer.rqstor:=id; coming:=TRUE; !so as subsequent dmn_rqsts dont claim extra space; END; 1290 IF spacefound THEN stage: = spaceclaimed ELSE q4space(dmn_rqst); !wait until space is available; IF tied AND NOT spacefound THEN BEGIN 1295 IF (IF dmn_info(did).here THEN dmn_info(did).d.tied NE 0 ELSE FALSE) THEN BEGIN !if the domain is genuinely tied here then; !see if there is a non-tied domain whose incarnation; !can be moved away; !in a really tight situation most incarnations; !will be shifted around; !however this will stop when there are none; 1305 !left that have not been shifted; REF(domain_incarnationc) ptr; BOOLEAN found; ptr:-driverq.q(low).Pred; WHILE ptr=/=NONE DO 1310 !work backwards along low priority queue; ``` ``` BEGIN IF dmn_info(ptr.did).d.tied=0 AND ptr.shifts<max_shifts THEN BEGIN !domain not tied here; 1315 opt_site:= optimum_site (ptr.total_size+ptr.d_size,0,i_chopf); IF opt_site NE O AND opt_site NE id THEN !found somewhere to go; 1320 found:=TRUE; retire(ptr); queue(driverq,ptr,high); !since there is no space here this incarnation; !will go to another site; END; END; IF found THEN ptr:-NONE ELSE ptr:-ptr.Pred; 1330 END; END; END; END; 1335 END of examine choice; PROCEDURE bring_together(dmn_rqst); REF(domain_incarnationc) dmn_rqst; 1340 !now request other sites to send segments; !and create temporary ones; INSPECT dmn_rqst DO · INSPECT processor DO BEGIN INTEGER i; 1345 IF count=1 THEN BEGIN send message(dmn info(did).d loc,d transfer); !domain at another site; !and not currently requested; count:=0; 1350 END; IF site NE id THEN BEGIN !processor not here; count:=count+1; 1355 p_seg_list.rqstor:=id; FOR i:=1 STEP 1 UNTIL max_param_segs DO IF params(i).status=incore THEN BEGIN count:=count+1; p_seg_list.a(i):=params(i).key; 1360 END ELSE p_seg_list.a(i):=0; send_message(site,p_seg_list); 1365 END; FOR i:=1 STEP 1 UNTIL max_param_segs DO ``` ``` BEGIN IF params(i).status=trans THEN add_seg(params(i)). 1370 !work segment created; ELSE IF params(i).status=ondisk THEN BEGIN count:=count+1; disk read.rqstor:=id; !can only be one read at a time; 1375 disk_read.key:=params(i).key; send_message(params(i).site,disk_read); !'site' is a diskcontroller; END; END; 1380 FOR i:=1 STEP 1 UNTIL max_local_segs DO IF locals(i).status=incore THEN BEGIN IF locals(i).site NE id THEN BEGIN 1385 count:=count+1; l_seg_list.a(i):=locals(i).key; END; END 1390 ELSE BEGIN l_seg_list.a(i):=0; IF locals(i).status=trans THEN add_seg(locals(i)); END; IF 1_site NE O AND 1_site NE id THEN 1395 BEGIN l_seg_list.rqstor:=id; send_message(l_site,l_seg_list); END; 1400 IF count>0 OR dmn_info(did).coming THEN dmn_rqst.Into(dmn_info(did).external_segs) ELSE put_in_ready_state(dmn_rqst); END of procedure bring together; 1405 PROCEDURE put_in_ready_state(inc); REF(domain_incarnationc) inc; 1410 BEGIN !assumes that all segments are at site; inc.site:=id; !give site of execution; inc.stage:=valid; 1415 inc.processor.Into(dmn_info(inc.did).work); !keep track of run state work; inc.domain:-dmn_info(inc.did).d; !domain must be here; 1420 IF inc.domain==NONE THEN error("ATTEMPT TO RUN WITHOUT DOMAIN"); IF inc.domain IN monitorc THEN BEGIN !not going to be there long so give favourable priority; inc.processor.rts:=timeslice; 1425 ``` ``` queue (driverq, inc, monitor); END ELSE queue(driverq,inc,inc.processor.priority); 1430 !the invalid form of inc had high priority; !an alternative would be to schedule into medium or; !low depending on rts, the remaining time slice; END of procedure put_in_ready_state; 1435 PROCEDURE retire(inc); REF(domain_incarnationc) inc; BEGIN !called when an incarnation is removed from driverq; 1440 !of dmn_info work list; inc.processor.Out; action_transfer(dmn_info(inc.did)); !does domain want to go to another site?; inc.Out; !removed from driverq completely; 1445 inc.stage:=seek_d_site; !set entry capability back to base state; !start counting forced migrations again; inc.shifts:=0; END of procedure retire; 1450 PROCEDURE action_transfer(h); REF(dmn_infoc) h; BEGIN PROCEDURE send_domain; 1455 BEGIN !broadcast(h.update); !tell other sites that domain is going to next_site; h.here:=FALSE; send_message(h.next_site,h.d); 1460 h.next_site:=0; END; IF h.next_site NE O AND h.here THEN !domain wanted elsewhere; BEGIN 1465 IF h.d IN monitorc THEN !must wait until domain is free; IF h.work.Empty AND h.external_segs.Empty THEN send_domain; END 1470 ELSE !can send domain and keep copy; BEGIN h.going:=h.copy:=TRUE; copyspace:=copyspace+h.d.size; !going = true protects copy from being deleted; 1475 !unil it is transmitted; send_domain; !decide after actual transmission if want to keep copy; END: END 1480 ELSE IF h.copy THEN BEGIN !domain is not wanted elsewhere; ``` ``` !see if want to delete copy; IF h.work.Empty AND h.external_segs.Empty THEN BEGIN IF NOT (spacegempty OR h.going) THEN 1485 delete_domain_copy(h.d.did) !tight for space; ELSE h.lasttime:=Time; END; 1490 END; END of procedure action_transfer; PROCEDURE domain_copy(domain); 1495 REF(domainc) domain; !this procedure is called by communication section; !when it has completed the transmission of a domain; BEGIN xfered_domains.incr; !statistics; 1500 IF domain IN monitore THEN BEGIN release(domain.size); !never keep copies of monitors; dmn_info(domain.did).d:-NONE; END 1505 ELSE INSPECT dmn_info(domain.did) DO BEGIN going:≃FALSE; IF ((NOT spaceqempty) AND work. Empty .AND external_segs.Empty) 1510 THEN delete_domain_copy(d.did); END of procedure domain_copy; 1515 PROCEDURE delete_domain_copy(did); INTEGER did; !this interacts with memory management; INSPECT dmn_info(did) DO BEGIN copy:=FALSE; 1520 copyspace:=copyspace-d.size; !give back space; release(d.size); !domain deleted; d:-NONE; END of delete_domain_copy; 1525 !*******end of domain management*********; ``` ``` PROCEDURE switch_context; !this procedure is only ever called from outside the kernelc; IF Idle THEN ACTIVATE THIS kernelc DELAY O 1530 !assume no switching delay; ELSE IF NOT maskf THEN BEGIN !when executing a domain incarnation; !have raised genuine interrupt; 1535 iflag := TRUE; maskf := TRUE; !but dont want to be interrupted now; REACTIVATE THIS kernelc DELAY 0; END: 1540 PROCEDURE execute(x); REF(domain incarnationc) x; 1545 !This procedure is the simulation of execution of; !a domain incarnation.; !Although an actual domain incarnation would be; !interruptable at any point of execution of the; !domain code it is assumed that the domain code; 1550 !is divided up into at most five steps and; !interrupts occur between these steps. The passage; !of time is simulated by 'hold' for the assumed; !execution time of a step; !followed by the 'instantaneous' execution of the; 1555 !step.; !The context of a domain incarnation is thus preserved; !by noting how long it has to remain in the 'hold'; !state, 'runtt', and which step it must execute; !next, 'next_step'.; 1560 !Steps, which are virtual procedures of the class domainc,; !have the following properties:; !1) at end must set the next set of values for runtt; !and next_step.; . !2) can call kernel primitives, which may remove this; 1565 !incarnation from drivery by manipulating cu.; !3) should exercise care in calling more than one kernel; !primitive in a step.; BEGIN REAL finisht; !work variable; 1570 IF x.domain==NONE THEN error("ATTEMPT TO MAKE SKELETON LIVE"); IF x.runtt NE O THEN BEGIN 1575 maskf:=FALSE; !normal domain execution is interruptable and pre-emptable; finisht:=Time+x.runtt; x.processor.service_timer.start; !statistics collection; Hold(x.runtt); !simulate time to complete action; 1580 !when the next instruction is executed either the; !processor has 'finished' or it has been interrupted; x.processor.service_timer.stop; x.processor.c_time:= ``` ``` x.processor.c_time+x.runtt-(finisht-Time); 1585 x.runtt:=IF iflag THEN finisht-Time ELSE 0; !no longer permitted to interrupt; maskf:=TRUE; 1590 IF NOT iflag THEN BEGIN !perform step whose execution time has just been simulated; . SWITCH s:=stpl,stp2,stp3,stp4,stp5; !a case statement; IF x.next step<1 OR x.next step>5 THEN 1595 error("DOMAIN NOT FORMULATED CORRECTLY"); GOTO s(x.next_step); stpl: x.domain.stepl(x); GOTO esac; stp2: x.domain.step2(x); GOTO esac; 1600 stp3: x.domain.step3(x); GOTO esac; stp4:x.domain.step4(x); GOTO esac; stp5: x.domain.step5(x); esac: END; END of procedure execute; 1605 REF(Link) ptr; 1610 initialization; WHILE running DO 1615 BEGIN IF iflag THEN BEGIN !simulate time to switch from user process; Hold(contextdelay); iflag := FALSE; 1620 END; ptr:-driverq.first; !examine top entry of driverq; 1625 IF q_trace AND ptr=/=NONE THEN BEGIN Outtext(" ("); Outint(id,2); Outchar(')'); ptime; Outtext(dissect(ptr)); END; 1630 !determine type of entry; IF ptr IN domain_incarnationc THEN BEGIN !cu always points to the current domain_incarnation which; !keeps its place in driverq unless a kernel primitive; !removes it; cu :- ptr; IF validated(cu) THEN BEGIN 1640 !continue if valid entry capability; ``` ``` ts_clock.set(cu.processor.rts); !for remaining timeslice; 1645 execute(cu); !A step of the domain code - consisting in fact; !of a 'hold' followed by l of the virtual; !procedures stepl...step5 - is performed; !an interrupt, during the 'hold' section, has occurred; !when control returns here.; !stop clock; ts clock.halt(cu.processor.rts); !after higher priority entries in driverq have; 1655 !been examined, execution of the remaining part; !of an interrupted step or the next step; !will take place.; 1660 IF NOT iflag THEN cu:-NONE; !clearing cu is indicative of the successful completion; !of a step; END ELSE cu:-NONE; !incarnation not executed because invalid; 1665 END 1670 ELSE BEGIN IF ptr=/=NONE THEN ptr.Out; INSPECT ptr 1675 WHEN clocke DO IF ptr==ts_clock THEN BEGIN !end of time slice for current domain incarnation; IF cu =/= NONE THEN BEGIN 1680 IF NOT cu.domain IN monitorc THEN BEGIN IF cu.processor.c_time GE longtimeslice THEN BEGIN cu.processor.rts:=longtimeslice; cu.processor.priority:=low; END ELSE cu.processor.rts:=timeslice; 1685 cu.Out; IF driverq.b entries=0 AND dmn_info(cu.did).next_site=0 !no other work and domain not wanted elsewhere; 1690 queue(driverq,cu,cu.processor.priority) ELSE BEGIN !redetermine best location for domain_incarnation to; !continue - gives domain chance to go to other sites; retire(cu); 1695 queue(driverq,cu,high); END; END ELSE cu.processor.rts:=timeslice; !give processor time to get out of monitor domain; ``` ``` 1705 WHEN consolec DO BEGIN- !input has arrived from a console; IF c_secretary.Prev == NONE THEN !see if in a queue; BEGIN !assume that it is not in driverq.; 1710 !note this means domain must be tied; queue(driverq,c_secretary,medium); c_secretary.stage:=valid; END; ptr.Into(c_arrival_list); !messages from all consoles kept in one list; 1715 END WHEN dmn_transfer DO BEGIN !request to transfer domain has arrived; IF dmn_info(did).next_site NE 0 THEN !domain promised to someone else; send_message(dmn_info(did). next_site,ptr) !pass on the request; ELSE IF NOT (dmn_info(did).here OR dmn_info(did).coming) !domain already gone elsewhere; THEN send_message(dmn_info(did).d_loc,ptr) ELSE !domain is here or coming; IF restor NE id THEN BEGIN INSPECT dmn_info(did) DO BEGIN 1730 d_loc:=next_site:=rqstor; !prepare for updating broadcast; IF update(1) == NONE THEN !update not initialized; BEGIN FOR w := 1 STEP 1 UNTIL n DO 1735 update(w):-NEW d_loc_update(did,rqstor); END ELSE FOR w:=1 STEP 1 UNTIL n DO 1740 update(w).new_site:=rqstor; END; . action_transfer(dmn_info(did)); !see if domain can be sent off immediately; 1745 END ELSE error("DOMAIN MANAGEMENT HAS FAILED"); END WHEN domainc DO 1750 BEGIN !domain has arrived from another site; site:=id; INSPECT dmn_info(did) DO BEGIN REF(domain_incarnationc) dr,f; 1755 ``` ``` IF NOT coming THEN !arrival unexpected e.g. from ipl; BEGIN claim(size,running); !memory space; IF NOT running THEN 1760 error("NO ROOM FOR A NEW DOMAIN"); FOR w:=1 STEP 1 UNTIL n DO update(w):-NEW d_loc_update(did,id); broadcast(update); !tell other sites it is here; 1765 d_loc:=id; END; coming:=FALSE; here:=TRUE; !alter state; WHILE NOT rqst_list.Empty DO !examine list of waitng domain requests; BEGIN dr:-rqst_list.Suc; queue(driverq,dr,high); !have chosen a strategy such that a request that; !is not going to be filled at this site is not acted; !upon if domain has been promised elsewhere; END; dr:-external_segs.Suc; 1780 WHILE dr=/=NONE DO !check incarnation(s) that have been waiting for; !domain to arrive to see if any are ready to run; BEGIN f:-dr.Suc; 1785 IF dr.count=0 THEN BEGIN dr.Out; put_in_ready_state(dr); 1790 dr:-f; END; END; ÊND 1795 WHEN d_loc_update DO !a domain has changed sites; BEGIN dmn_info(did).d_loc:=new_site; END 1800 WHEN 1_seg_listc DO BEGIN !request to transfer a list of local segments; INTEGER i; REF (segmentc) s; 1805 FOR i:=1 STEP 1 UNTIL max_local_segs DO IF a(i) NE 0 THEN s:-seg_table(retrieve(a(i))); !fetch segment; xfered_locals.incr; !update statistics: send_message(rqstor,s); !transmit; 1810 END; END ``` ``` WHEN p_seg_listc DO BEGIN 1815 !request to transfer processor segment and; !possible parameters; INTEGER i; send_message(rqstor,seg_table(retrieve(p_key))); xfered_processors.incr; 1820 !send processor segment; FOR i:=1 STEP 1 UNTIL max_param_segs DO IF a(i) NE O THEN BEGIN send_message(rqstor,seg_table(retrieve(a(i)))); xfered_locals.incr; 1825 END; END WHEN s_channelc DO BEGIN !transmission to another site completed; REF(contentc) m; m:-ptr QUA s_channelc.m; !retain reference to message just sent; !now see if more messages to be sent; 1835 IF NOT(cq.Empty AND sq.Empty) THEN signal channel ((IF cq.Empty THEN sq.Suc ELSE cq.Suc) QUA contentc) !none left; ELSE 1840 channel_busy:=FALSE; !now free space from previous message; !(could be time consuming); IF m IN domainc THEN domain_copy(m QUA domainc) !determine if keeping a copy of domain code; ELSE IF m IN segmentc THEN delete_seg(m QUA segmentc); !return space; !short control messages are assumed not to interact with; !memory management; END 1850 WHEN segmente DO !domainc already dealt with; BEGIN !processor or local segment has arrived; 1855 INTEGER new_did; REF(virtual_processor) p; REF(domain_incarnationc) f; IF ptr IN virtual_processorc THEN BEGIN p:-ptr; 1860 new_did:=p.e_stack(p.stackp).did; END ELSE BEGIN !assume that it is local segment; p:-ptr QUA local_seg.pr; 1865 new_did:=ptr QUA local seg.did; END; ``` ``` !locate incarnation they belong to; 1870 f:-dmn_info(new_did).external_segs.Suc; WHILE (IF f == NONE THEN FALSE ELSE f.processor = /= p) DO f:-f. Suc; !search for incarnation record; IF f==NONE THEN error("SEGMENT HAS LOST ITS DOMAIN") 1875. ELSE BEGIN f.count:=f.count-1; !one more segment has arrived; IF f.count=0 AND (dmn_info(new_did).here OR 1880 dmn info(new did).copy) THEN BEGIN f.Out; !of external_segs list; put_in_ready_state(f); !can run because all segments here; 1885 END: END; END 1890 OTHERWISE BEGIN IF NOT spaceqempty THEN BEGIN 1895 !have processes waiting for space but.none running; IF spaceq.total_entries=qfs(id) AND NOT deadlock warning THEN BEGIN 1900 ptime; Outtext("POSSIBLE DEADLOCK AT SITE "); Outint(id,2); Outtext(" NUMBER WAITING="); Outint(spaceq.total entries,2); 1905 Outimage; deadlock_warning:=TRUE; END; END; idle_timer.start; 1910 Passivate; idle_timer.stop; !accumulate idle time; END: 1915 END; END; error("KERNEL HAS STOPPED RUNNING"); END of class kernelc; ``` ``` CLASS dmn_infoc; 1925 !this class is a data structure holding all information that the; !kernel needs to know about a domain; BEGIN REF(domainc) d; !actual reference to domain; BOOLEAN 1930 copy, !true if only a copy of the domain is here; !true when this site has requested domain to be sent here; 1935 !true when domain is actually at this going; !true when domain is in transit between sites; INTEGER !estimate of site of original domain; d loc, next_site; !non-zero when domain reserved for another site; REF(Head) !list of all 'ready to run' incarnations of domain; 1945 external segs, !list of all incarnations waiting for segments; !from other sites; rqst_list; !list of all rosts to have optimum site calculation performed; !for copies last time it was used; REAL lasttime; REF(d_loc_update) ARRAY update(1:n); !kept for efficieny reasons; work:-NEW Head; external_segs:-NEW Head; rqst list:-NEW Head; copy:=FALSE; coming:=FALSE; here:=FALSE; next_site:=0; END of class dmn_infoc; 1960 contentc CLASS dmn transfer; 1965 BEGIN INTEGER did, rqstor; !for requesting the transmission of code and possible public; !segments to another site (rqstor); size:=32; END of class dmn_transfer; 1970 contentc CLASS d_loc_update(did,new_site); INTEGER did,new_site; !for informing sites of new domain locations; 1975 BEGIN ``` ``` TEXT PROCEDURE dump; dump:-Copy("D_LOC_UPDATE"); size:=32; 1980 END; contentc CLASS domain_incarnationc(processor); 1985 REF(virtual_processorc) processor; !this is basically an entry capability; !the data it contains is fleshed out by various procedures; !in the kernel to make the capability valid; 1990 INTEGER stage; !progress indicator in making capability valid; INTEGER did; !identity of domain (going to be) entered; REF(domainc) domain; !set just before entering domain; 1995 REF (local_seg) ARRAY locals(l:max_local_segs); INTEGER choice; !site calculated as 'best' for incarnation; 2000 INTEGER shifts; !count of number of times incarnation forced to another site; INTEGER next_step; !entry point information; 2005 REAL runtt; REAL local_data; !required to simulate data stored in local_segments; !the above are all that are strictly necessary; 2010 !the rest aid computation; INTEGER d site,p site,l site; !sites of domain, processor and parameter, and local segments; INTEGER d_size,p_size,l_size; !size of code (& data-base), processor (& parameter); 2015 !and local segments; INTEGER total_size, lof all segments except domain segments but including those; !that are to be created and on disk; 2020 extra space; !size of segments not resident at chosen site or to be created; INTEGER count; !number of segments required from other sites; 2025 INTEGER site; INTEGER i; PROCEDURE re_initialization(didn); INTEGER didn; !sets capability back to base state; BEGIN stage:=seek_d_site; runtt:=0; next_step:=1; did:=didn; ``` ``` FOR i:=1 STEP 1 UNTIL max_local_segs DO locals(i).status:=locals(i).default:=null; 2035 END of re_initialization; TEXT PROCEDURE dump; BEGIN 2040 !for diagnostic identification - 12 chars long; TEXT dumpv; dumpv :- Copy("DI P= D= dumpv.Sub(6,2).Putint(processor.pid); dumpv.Sub(10,2).Putint(did); 2045 dump:-dumpv; END; size:=32; 2050 !for transmission over communication links; FOR i:=1 STEP 1 UNTIL max_local_segs DO locals(i):-NEW local_seg(0,processor); !instead of creating a new local segment every time one is; !used the same template is used; 2055 END of domain_incarnationc; 2060 segmentc CLASS domainc(did); INTEGER did; !identification number; VIRTUAL: PROCEDURE !executed on entering a domain; step2, step3, step4, step5; 2065 !optional extra 'instructions'; BEGIN INTEGER !if non-zero fixed site for domain; tied; 2070 INTEGER i; PROCEDURE interdomain_call(x,new did); REF (domain_incarnationc) x; INTEGER new_did; BEGIN 2075 interdmn_jump(x,x.processor.fetch_c(new_did)); !set up new entry capability; PROCEDURE return(x); REF(domain_incarnationc) x; 2080 INSPECT x DO BEGIN INTEGER i; FOR i:=1 STEP 1 UNTIL max_local_segs DO IF locals(i).status=incore THEN 2085 !determine what to do with local segments; IF locals(i).default=null THEN INSPECT k(x.site) DO delete_seg(locals(i)); END; 2090 ``` ``` interdmn_jump(x,processor.return); !retrieve previous entry capability; END of return; PROCEDURE interdmn_jump(x,y); 2095 . REF (domain_incarnationc) x,y; !set in train the transfer of virtual processor; !from incarnation x to y; BEGIN FOR i:=1 STEP 1 UNTIL max_param_segs DO 2100 x.processor.params(i).did:=y.did; !mark parameter segments as belonging to new domain; INSPECT k(x.site) DO BEGIN retire(x); !remove current domain incarnation from driverq; 2105 queue(driverq,y,high); END; new_incarnations.incr; !statistic; END of interdmn_jump; 2110 REF(domain_incarnationc) PROCEDURE putative_return(x); REF(domain_incarnationc) x; BEGIN !gives the entry capability for a return but does not; !instigate the return; 2115 return(x); x.processor.Current.Out; !of driverq; putative_return:-x.processor.Current; END; 2120 PROCEDURE setup_disk_read(x,size); REF(domain_incarnationc) x; INTEGER size; 2125 !for preparing the parameters of a disk read; x.processor.simple_parameter:=size; !considerably simplified; 2130 TEXT PROCEDURE dump; BEGIN !diagnostic; TEXT t; t:-Copy("DOMAIN t.Sub(7,2).Putint(did); dump:-t; 2135 END; key := did; default:=status:=incore; !always; 2140 INSPECT k(site) DO int(THIS domainc); !instal itself; END; 2145 CLASS formatc(did); INTEGER did; ``` ``` !for handling 'compile-time' information about domain structure; VIRTUAL: PROCEDURE format; 2150 BEGIN PROCEDURE format(1); REF(local_seg)ARRAY 1; ; !default; dp(did):-THIS formatc; 2155 !make universally available; END; REF(formatc) ARRAY dp(l:fixed_domains); 2160 domainc CLASS monitore: BEGIN !size of code segment; INTEGER c_size, !size of public (data_base) segment; db_size; 2165 !n.b. db_size can not be zero.; INNER: size:=c_size+db_size; END of class monitore; 2170 monitorc CLASS secretaryc; BEGIN !in this simulation all the monitors that have condition; 2175 !queues also have secretaries; !conditon queue; REF(head) my q; !a virtual processor can suspend; 2180 !itself on the condition queue; PROCEDURE suspend; k(site).cu.Into(my_q); !this assumes that the domain is tied down; 2185 PROCEDURE restart_processor; !removes the first processor from condition queue; !because still at same site could be ready to; !continue in monitor; INSPECT k(site) DO 2190 BEGIN REF(domain_incarnationc) inc; inc:-my_q.Suc; IF inc=/=NONE THEN queue (driverq,inc,IF inc.stage=valid THEN monitor ELSE high); END of procedure restart_processor; 2195 PROCEDURE wait_for_signal; k(site).cu.Out; !secretary processor removed from driverq; 2200 PROCEDURE create_secretary(secretary,u); NAME secretary; REF(domain incarnationc) secretary; INTEGER u; ``` ``` BEGIN 2205 REF(virtual_processor) pr; INSPECT k(site) DO pr:-NEW virtual_processorc(site,max_consoles+did,u); claim(pr.size,running); 2210 pr.service_timer.Out; !not giving user service; secretary:-pr.fetch_c(did); secretary.domain:-THIS domainc; secretary.stage:=valid; 2215 !always ready to run; END: END; 2220 my_q :- NEW Head; tied:=site; !because secretary is only known at one site; END of class secretaryc; 2225 segmentc CLASS virtual_processor (pid,u); INTEGER pid, !identification number; u; !random number seed to determine execution path; 2230 BEGIN INTEGER priority; !determines scheduling; REAL rts, !remaining time slice; c time; !processing time received since last command started; 2235 REF(local_seg) ARRAY params(l:max_param_segs); !there is one A_list for the virtual processor; !local segments are moved to and from it if necessary; INTEGER simple parameter; !for non array type data; 2240 INTEGER unique; INTEGER PROCEDURE uniquenumber; BEGIN unique:=unique+l; IF unique < l6rffff !l6bits;</pre> 2245 THEN uniquenumber:=unique ELSE error("PROCESSOR HAS RUN OUT OF UNIQUE NUMBERS"); END; REF(domain_incarnationc) ARRAY e_stack(1:stack_depth); 2250 !for keeping control of sequence of domains visited; INTEGER stackp; INTEGER sameness; !counts how many times processor on same domain call sequence; 2255 REF(domain_incarnationc) PROCEDURE Current; !the incarnation the processor is in or will be in when; !it next executes; Current:-e_stack(stackp); 2260 REF(domain_incarnationc) PROCEDURE fetch_c(did); ``` ``` INTEGER did; IF stackp < stack_depth THEN !set up incarnation template; stackp:=stackp+1; 2265 IF e stack(stackp).did=did THEN !ghost; sameness:=sameness+1 ELSE sameness:=1; e stack(stackp).re initialization(did); dp(did).format(e_stack(stackp).locals); !set up temporary space etc; 2270 fetch_c:-e_stack(stackp); END ELSE error(fillin("STACK OVERFLOW FOR PROCESSOR", pid)); REF(domain_incarnationc) PROCEDURE return; 2275 IF stackp>1 THEN BEGIN stackp:=stackp-l; return: -e stack(stackp); END ELSE error(fillin("STACK UNDERFLOW FOR PROCESSOR", pid)); REF(timer) service_timer; !the next 4 items do not logically belong here; !i.e. not part of processor base segment; 2285 !they are included for program efficiency; REF(dmn_transfer) d_transfer; REF(p_seg_listc) p_seg_list; REF(l_seg_listc) l_seg_list; REF(disk_rqst) disk_read; 2290 priority:=medium; rts:=timeslice; 2295 service_timer :- NEW timer("SERVICE TIME", usage); size := 200; `key:=pid+fixed_domains; status:=default:=incore; FOR w:=1 STEP 1 UNTIL stack_depth DO 2300 e stack(w):-NEW domain incarnationc(THIS virtual processorc); FOR w:=1 STEP 1 UNTIL max_param_segs DO params(w):-NEW local_seg(site,THIS virtual_processorc); d_transfer:-NEW dmn_transfer; p_seg_list:-NEW p_seg_listc(key); 2305 1_seg_list:-NEW l_seg_listc; disk_read:-NEW disk_rqst; END of class virtual_processor; 2310 contentc CLASS p_seg_listc(p_key); INTEGER p_key; BEGIN !carries kernel request for processor and parameter segsments; INTEGER restor; INTEGER ARRAY a(1:max_param_segs); size:=32; ``` ``` END; 2320 contentc CLASS l_seg_listc; !for requests for local segments; BEGIN INTEGER rqstor; INTEGER ARRAY a(1:max_local_segs); 2325 size:=32; END; segmentc CLASS local_seg(pr); REF(virtual_processor) pr; 2330 BEGIN INTEGER did; INTEGER PROCEDURE setkey; setkey:=pr.pid*16rffffff+site*16rffff+pr.uniquenumber; !created before use and reused for sake of program efficiency; !site, size and key have to be given each time; 2335 PROCEDURE make_workspace(d_id,newsize); INTEGER d id, newsize; BEGIN 2340 did:=d_id; key:=setkey; !so as created on domain entry; status:=trans; size:=newsize; END; 2345 PROCEDURE make_disk_read(newsize); INTEGER newsize; BEGIN !for setting up the parameter segment for a disk read; 2350 key:=setkey; status:=ondisk; size:=newsize; END; TEXT PROCEDURE dump; 2355 dump:-fillin("L_SEG * P",pr.pid); END of class local_seg; 2360 PROCEDURE move(1from, 1to); REF(local_seg) lfrom,lto; !for transferring a segment into or out of A_list; BEGIN !an error in simula runtime system prevents swopping 'REFs'; 2365 INSPECT 1from DO BEGIN lto.pr:-pr; lto.size:=size; lto.site:=site; 1to.key:=key; 2370 lto.default:=default; lto.status:=status; lto.did:=did; !assume that Ito previous status not incore; IF status=incore OR status=desc THEN INSPECT k(site) DO seg_table(retrieve(key)):-lto; 2375 ``` END; !keep the same number of segment templates in the system; lfrom.status:=null; END; 2380 ``` PROCEDURE ipl; BEGIN INTEGER ul,nn,j; !random number seed; ul:=random_seed; NEW user_supervisor(l,supern); 2385 !simulate part of ipl; NEW command(cnsl_site,commandn); FOR nn:=1 STEP 1 UNTIL max_disks DO NEW diskhandler(nn*(n//max_disks),diskl+nn-l,n+nn,ul*(2*nn+l)); !spread handlers around to different sites; FOR nn:=ipld+l STEP 1 UNTIL ipld+compl DO NEW compiler(Nod(nn,n)+1,nn); FOR nn:=ddl STEP l UNTIL ddu DO NEW typel(Mod(nn,n)+l,nn); 2395 FOR nn:=mntrl STEP 1 UNTIL mntru DO NEW type2(Mod(nn,n)+1,nn); FOR nn:=1 STEP 1 UNTIL max_consoles DO 2400 BEGIN console(nn) :- NEW consolec(nn,(2*Randint(1,1000,ul)+1)); ACTIVATE console(nn) DELAY 5000; !give system time to settle down; END; 2405 END of procedure ipl; ``` ``` domainc CLASS type1; BEGIN !this class simulates trivial commands; loverall about half the commands make at least I disk transfer; !the average processor time is around 200 msec; PROCEDURE stepl(x); REF(domain_incarnationc) x; 2415 BEGIN IF full_diags THEN BEGIN TEXT t; AT SITE t:-Copy("PROCESSOR ENTERS DOMAIN t.Sub(11,2).Putint(x.processor.pid); 2420 t.Sub(28,2).Putint(did); t.Sub(39,2).Putint(x.site); ptime; Outtext(t); END; x.next_step:=2; 2425 x.runtt:=Negexp(1/100000,x.processor.u); END of procedure stepl; PROCEDURE step2(x); REF (domain_incarnation) x; 2430 BEGIN IF Draw(0.25,x.processor.u) THEN !going to make a disk transfer; BEGIN setup_disk_read(x,512); !read 512 bytes; interdomain_call(x,diskhandlern(x.processor.pid)); 2435 x.next_step:=5; x.runtt:=200; END ELSE BEGIN x.next_step:=3; x.runtt:=0; END; END of step2; 2440 PROCEDURE step3(x); REF(domain_incarnationc) x; !determine next domain to be entered; BEGIN 2445 REF(virtual_processor) p; INTEGER new_did; p:-x.processor; IF Draw(0.5, p.u) AND p.stackp<stack_depth THEN BEGIN 2450 new_did := Randint((did+1),mntru,p.u); IF full_diags THEN BEGIN ptime; Outint(p.pid,6); Outtext(" CHOOSES"); Outint(new_did,6); END: 2455 interdomain call(x,new_did); END; x.next_step:=4; x.runtt:=100; 2460 END of procedure step3; PROCEDURE step4(x); REF(domain_incarnationc) x; ``` ``` BEGIN IF full_diags THEN BEGIN 2465 ptime; Outint(x.processor.pid,6); Outtext(" RETURNS TO/REMAINS AT"); Outint(did,4); Outimage; END; 2470 return(x); END of procedure step4; PROCEDURE step5(x); REF(domain incarnationc) x; 2475 BEGIN !completed a disk read; move(x.processor.params(1),x.locals(2)); x.next_step:=3; x.runtt:=0; END of step5; 2480 size:=1024; NEW typelf(did); !to set up domain correctly; END of class typel; 2485 formatc CLASS typelf; BEGIN PROCEDURE format(1); REF(local_seg) ARRAY 1; 1(1).make_workspace(did,(ddu+2-did)*128); !different size for each domain to get different behaviour; END of typelf; ``` ``` monitorc CLASS type2; !this class simulates actions involving the use of global tables; 2495 BEGIN PROCEDURE step1(x); REF(domain_incarnationc) x; BEGIN 2500 IF full_diags THEN BEGIN TEXT t; t:-Copy("PROCESSOR ENTERS MONITOR AT SITE ''); t.Sub(11,2).Putint(x.processor.pid); t.Sub(29,2).Putint(did); t.Sub(40,2).Putint(x.site); 2505 ptime; Outtext(t); END; x.next_step:=2; x.runtt:=Negexp(1/100000,x.processor.u); 2510 END of stepl; PROCEDURE step2(x); REF(domain_incarnationc) x; return(x); 2515 c_size:=400; db size:=(mntru-did+l)*max_consoles*32; !expect global tables to be bigger the more users there are; NEW type2f(did); 2520 END of type2; formatc CLASS type2f; BEGIN PROCEDURE format(1); REF(local_seg) ARRAY 1; 2525 1(1).make_workspace(did,10*did); !space for a small stack; END of type2f; ``` ``` 2530 domainc CLASS compiler; Ithis domain interacts only with the diskhandler and makes large; !computational demands; BEGIN REAL ARRAY a,b(1:7); PROCEDURE stepl(x); 2535 REF(domain_incarnation) x; BEGIN IF full_diags THEN BEGIN TEXT t; t:-Copy("PROCESSOR ENTERS COMPILER"); 2540 t.Sub(11,2).Putint(x.processor.pid); ptime; Outtext(t); END; x.next_step:=2; x.local_data:=Linear(a,b,x.processor.u)* 1.0&6; 2545 END of stepl; PROCEDURE step2(x); REF(domain_incarnation) x; 2550 BEGIN IF x.processor.params(1).status=incore THEN INSPECT k(x.site) DO delete_seg(x.processor.params(1)); !free previous buffer; IF x.local_data > 0 THEN 2555 BEGIN x.runtt:=Erlang(1.0\&-6,6,x.processor.u); !we assume an average of 12 lines/sec compilation speed; !with 2 disk transfers for every 12 lines; x.local_data:=x.local_data-x.runtt; 2560 setup_disk_read(x,4096); interdomain_call(x,diskhandlern(x.processor.pid)); x.next_step:=3; END ELSE 2565 return(x); END of step2; PROCEDURE step3(x); REF(domain_incarnationc) x; 2570 !disk write; x.processor.params(1).status:=desc; interdomain_call(x,diskhandlern(x.processor.pid)); x.next_step:=2; x.runtt:=500; END of step3; 2575 size:=12000; a(1):=0; a(2):=0.27; a(3):=0.54; a(4):=0.78; a(5):=0.88; 2580 a(6):=0.93; a(7):=1.0; b(1):=0.5; b(2):=4; b(3):=8; b(4):=16; b(5):=40; b(6):=80; b(7):=200; !cumulative density function for cpu times; NEW typelf(did); 2585 END of class compiler; ``` ## A BLANK PAGE ``` domainc CLASS user_supervisor; BEGIN 2590 !supervise the 'interpretation' of users code; !can soak up a lot of cpu time; PROCEDURE stepl(x); REF(domain_incarnationc) x; 2595 BEGIN IF full_diags THEN BEGIN Outtext(fillin ptime; ("EXECUTION OF USER CODE BY PROCESSOR", x.processor.pid)); 2600 x.local_data:=Linear(userp,usert,x.processor.u)*&6; setup_disk_read(x,Randint(300,16000,x.processor.u)); !for code from disk; interdomain_call(x,diskhandlern(x.processor.pid)); 2605 x.next_step:=2 END of stepl; PROCEDURE step2(x); REF (domain_incarnationc) x; BEGIN 2610 move(x.processor.params(1),x.locals(2)); !code lives in local segment 2; x.runtt:=200; x.next_step:=3; END of step2; 2615 PROCEDURE step3(x); REF(domain_incarnationc) x; IF x.local data>0 THEN BEGIN x.runtt:=Negexp(1/250000,x.processor.u); 2620 !mean headway between disc operations is 250msecs; this is twice the equivalent emas rate but we must allow for !overlays or equivalent; x.local_data:=x.local_data-x.runtt; INSPECT x.processor DO 2625 BEGIN IF Draw(0.5,u) AND params(1).status=incore THEN params(l).status:=desc; !for write; END 2630 ELSE BEGIN IF params(1).status=incore THEN INSPECT k(x.site) DO delete_seg(params(1)); 2635 simple_paramater:=8192; !for read; END: END; interdomain_call(x,diskhandlern(x.processor.pid)); END 2640 ELSE BEGIN IF x.processor.params(1).status=incore THEN INSPECT k(x.site) DO delete_seg(x.processor.params(1)); ``` ``` !supervisor finished; 2645 return(x); END of step3; size:=4000; NEW supervisorf(did); END of class user_supervisor; 2650 formatc CLASS supervisorf; BEGIN PROCEDURE format(1); REF (local_seg) ARRAY 1; 2655 BEGIN 1(1).make_workspace(did, Randint(500, 8000, 1(1).pr.u)); END; END; 2660 ``` ``` secretaryc CLASS diskhandler(disk,u); INTEGER disk,u; BEGIN !This domain handles both writes to and reads from disk.; !Requests are queued depending on the priority of the; 2665 !processors making the request.; !When in overload situation low priority processors are; !suspended after they have issued write requests until; !situation improves.; 2670 REF(virtual_processor) pr; REF(domain_incarnationc) next_inc; BOOLEAN transfer_in_progress, read_next, !true if previous operation was a write; overload; !set to give priority to writes to free memory; REF(Head) wfreeq,wq; !used to manage limited read before write scheme; 2680 REF(Head) wql,wqh; !low and high priority write queues feed into wq; REF(Head) rql,rqh; !read queues; REF(l_seg_listc) disk_write_rqst; REF(Link) trans_seg; 2685 BOOLEAN warning message; !true when printed warning about deadlock possibility; PROCEDURE signal_disk_write; 2690 BEGIN !the kernel where the segment to be written resides is; !requested to send the segment straight to the disk; disk_write_rqst.a(1):=wq.Suc QUA segmentc.key; INSPECT k(site) DO send message(wq.Suc QUA segmentc.site,disk write rqst); 2695 trans_seg:-wq.Suc; trans_seg.Out; IF NOT (wqh. Empty AND wql. Empty) AND NOT wfreeq. Empty THEN BEGIN !move another write request into pipeline; next_inc:-IF wqh.Empty THEN wql.Suc ELSE wqh.Suc; 2700 move(next_inc.processor.params(1), wfreeq.Suc QUA local_seg); wfreeq.Suc.Into(wq); IF next_inc.processor.priority=low THEN 2705 BEGIN IF overload OR NOT my_q.Empty THEN BEGIN next_inc.Into(my_q); !hold back to allow other processors to complete; 2710 IF overload THEN next_inc:-NONE ELSE next_inc:-my_q.Suc; END; END; IF next inc=/=NONE THEN 2715 INSPECT k(site) DO queue(driverq,next_inc,monitor); !in monitor and still valid; ``` ``` BOOLEAN PROCEDURE initiate_read; !if there is a read to be done, starts it and returns true; 2725 initiate_read:=NOT(rqh.Empty AND rql.Empty); IF NOT rgh. Empty THEN k(site).send_message(disk,rqh.Suc QUA contentc) ELSE IF NOT rq1. Empty THEN k(site).send message(disk,rql.Suc QUA contentc); 2730 END of initiate_read; PROCEDURE step1(x); REF(domain_incarnationc) x; 2735 BEGIN IF full diags THEN BEGIN ptime; Outtext(fillin("DISK HANDLER ACTIVATED FOR PROCESSOR", 2740 x.processor.pid)); Outimage; END; x.runtt:=200; x.next step:=2; 2745 END of stepl; PROCEDURE step2(x); REF(domain_incarnationc) x; !for a disk write params(1) has a segment desc(riptor) while; !for a read simple_parameter describes the requirements; IF x.processor.params(1).status=desc THEN BEGIN !write; IF NOT wfreeq. Empty THEN BEGIN !go straight into delay line buffer; move(x.processor.params(1), wfreeq.Suc QUA local_seg); wfreeq.Suc.Into(wq); IF NOT transfer_in_progress THEN BEGIN !can use disk straight away; 2760 signal_disk_write; transfer_in progress:=TRUE; END; END ELSE BEGIN 2765 !delay line full so processor has to wait; IF x.processor.priority=low THEN x.Into(wql) ELSE x.Into(wqh); END; x.next_step:=3; x.runtt:=400; 2770 END ELSE BEGIN !entered to do a disk réad; ``` ``` 2775 x.processor.params(1).make_disk_read (x.processor.simple_parameter); x.processor.params(1).site:=disk; !identify disk that will read segment; next_inc:-putative_return(x); !prepare entry capability for when read complete; 2780 IF transfer_in progress THEN next inc.Into(IF x.processor.priority=low THEN rql ELSE rqh) !suspend for secretary to look after; ELSE 2785 BEGIN transfer_in_progress:=TRUE; INSPECT k(site) DO send_message(disk,next_inc); END of step2; 2790 PROCEDURE step3(x); RÉF (domain incarnationc) x; BEGIN return(x); 2795 END of step3; PROCEDURE step4(x); !executed by secretary processor; REF(domain_incarnationc) x; BEGIN 2800 !in a normal situation read done before writes; !unless wq is full in which case done turn; !and turn about; !in overload situation all writes and high priority reads; 2805 !are done turn and turn about; IF trans_seg=/=NONE THEN BEGIN trans seg:-NONE; read_next:=TRUE; 2810 END ELSE read_next:=FALSE; IF read next THEN overload:=k(site).overload; IF overload THEN 2815 BEGIN IF NOT((read_next AND NOT rqh.Empty) OR wq.Empty) THEN signal_disk_write ELSE IF NOT initiate_read THEN 2820 BEGIN transfer in progress:=FALSE; !could be in trouble here as nothing to do yet; !system close to deadlock; IF NOT warning_message THEN BEGIN ptime; Outtext("DISKHANDLER IMPOTENT"); Outimage; 2825 warning message:=TRUE; END; END END ELSE 2830 IF NOT(wq1. Empty AND wqh. Empty) THEN BEGIN ``` ``` IF NOT read_next OR (rql.Empty AND rqh.Empty) THEN signal_disk_write ELSE initiate_read; 2835 END ELSE BEGIN !the normal situation - reads before writes; IF NOT initiate_read THEN 2840 BEGIN IF NOT wq.Empty THEN signal_disk_write ELSE BEGIN !nothing to do; 2845 transfer_in_progress:=FALSE; IF NOT my_q.Empty THEN BEGIN restart_processor; !judge it safe to release one held up processor; warning_message:=FALSE; 2850 END; END; END; END; wait_for_signal; 2855 x.runtt:=200+300*(my_q.Cardinal+rql.Cardinal); !the bigger the disk queues the more time spent; !manipulating them; END of step4; 2860 c_size := 512; db_size:=2048; wq:-NEW Head; wfreeq:-NEW Head; wqh:-NEW Head; wq1:-NEW Head; 2865 rgh:-NEW Head; rql:-NEW Head; disk write rqst:-NEW l_seg_listc; disk_write_rqst.rqstor:=disk; FOR w:=1 STEP 1 UNTIL max_writes_pending DO 2870 NEW local_seg(0,NONE).Into(wfreeq); NEW formatc(did); INSPECT k(site) DO BEGIN create_secretary(d_secretary,u); d_secretary.next_step:=4; 2875 d_secretary.runtt:=200; ACTIVATE NEW disk_controller(disk, site, d_secretary) DELAY 0; END; END of diskhandler; 2880 INTEGER PROCEDURE diskhandlern(pid); INTEGER pid; !rule for associating virtual processors with disks; diskhandlern:=diskl+Mod(pid,max_disks); 2885 ``` ``` secretaryc CLASS command; !this domain analyses console input - in a random fashion; BEGIN REF(virtual processor) pr; 2890 REF(Head) c_wait_list; INTEGER active_processors; PROCEDURE stepl(x); 2895 REF(domain_incarnationc) x; x.next_step:=2; x.runtt:=200; END of stepl; 2900 PROCEDURE step2(x); REF(domain_incarnationc) x; BEGIN REAL r; INTEGER new_did; r:=Uniform(0,1,x.processor.u); 2905 new_did:= IF r<0.09 THEN Randint(ipld+l,ipld+compl,x.processor.u)</pre> ELSE IF r<0.26 THEN supern !user program; ELSE Randint(ddu,mntru,x.processor.u); !typel or type2; interdomain call(x, new did); 2910 !choose new domain; IF new_did < ddl THEN BEGIN !see if can accept another incarnation of a large domain; .IF k(site).overload OR active_processors>chopfactor OR 2915 NOT c_wait_list.Empty THEN BEGIN x.processor.Current.Into(c_wait_list); chopcount.incr; !statistics; IF active_processors<chopfactor AND NOT k(site).overload 2920 queue(k(site).driverq,c_wait_list.Suc,high) !free first in queue if nothing overloaded; ELSE BEGIN active_processors:=active_processors-l; 2925 k(site).qfs(site):=k(site).qfs(site)-l; !taken out of driverq to wait until system is; !less congested; END: END; 2930 END; x.next_step:=3; x.runtt:=50; END of step2; PROCEDURE step3(x); REF(domain incarnationc) x; 2935 !executes here when finished processing; BEGIN ACTIVATE console(x.processor.pid) DELAY contextdelay; !notify console that service is complete; 2940 x.next_step:=1; x.runtt:=0; active_processors:=active_processors-1; k(site).retire(x); !in theory should go in my_q; ``` ``` k(site).qfs(site):=k(site).qfs(site)-l; !see if any chopped processors can run; 2945 IF (IF c_wait_list.Empty THEN FALSE ELSE active processors=0 OR (active_processor<chopfactor AND NOT k(site).overload)) THEN BEGIN INSPECT k(site) DO BEGIN 2950 queue(driverq,c_wait_list.Suc,high); qfs(id):=qfs(id)+1; active_processors:=active_processors+l; END: END: 2955 END of step3; PROCEDURE step4(x); REF(domain incarnationc) x; !this is the code executed by the secretary processor; 2960 BEGIN REF(linkage) ptr; ptr:-c_arrival_list; FOR ptr:-ptr.Suc WHILE ptr=/=NONE DO BEGIN pr:-ptr QUA consolec.pr; 2965 INSPECT k(site) DO BEGIN queue(driverq,pr.e_stack(pr.stackp),high); !removes from my_q (if there); active_processors:=active_processors+1; qfs(id):=qfs(id)+l; 2970 END: END; c arrival_list.Clear; !all outstanding inputs dealt with; wait for signal; 2975 x.runtt:=200; END of step4; !initialization; 2980 ----- NEW formatc(did); c_size:=512; db_size:=120*max_consoles; !buffer space; INSPECT k(site) DO BEGIN create secretary(c_secretary, 1); c_secretary.next_step:=4; 2985 c_secretary.runtt:=200; END: c_arrival_list:-NEW Head; c_wait_list:-NEW Head; END of class command; 2990 ``` ``` REF(counter) channel_use; REF(counter) control_count; Process CLASS s_channelc(orgn); 2995 INTEGER orgn; !it is assumed that each site can transmit to only one other; ! site at a time but that a site can receive many; !messages simultaneously; BEGIN !all messages are of type contentc; 3000 REF(contentc) m; PROCEDURE initiate(message); REF(contentc) message; BEGIN 3005 m:-message; !channel deals with one message at a time; ACTIVATE THIS s_channelc DELAY(m.size*mesdelay); !time to transmit; END; 3010 WHILE running DO BEGIN channel_use.add(m.size); !update statistics; IF m.size=32 THEN control_count.incr; 3015 IF m.dest LE n THEN BEGIN k(m.dest).int(m) !message arrival is signalled; END ELSE dsk(m.dest).int(m); 3020 INSPECT k(orgn) DO BEGIN queue(driverq, THIS s_channelc, high); switch_context; !interrupt kernel to notify end of transmission; 3025 !dealt with message; Passivate; END; END of s_channelc; 3030 ``` ``` !part of the public segment of the command domain; 3035 Process CLASS consolec(userid,u); INTEGER userid. !random number seed; u; BEGIN REF(.virtual_processor) pr; REF(counter) completed_commands; 3040 REF(timer) response_timer,think_timer; REAL rt; REAL PROCEDURE thinktime; thinktime:= Negexp(1/30,u)*\&6; 3045 NEW groupheading(fillin("CONSOLE", userid)); think timer :- NEW timer("THINKING TIME", NONE); response_timer :- NEW timer("RESPONSE TIME", total_response); pr:- NEW virtual_processor(cnsl_site,userid,u); 3050 pr.fetch_c(commandn); !initialize virtual processor to serve console; completed_commands:-NEW counter("COMPLETED COMMANDS"); 3055 INSPECT k(cnsl_site) DO claim(pr.size,running); !space for process base; 3060 WHILE running DO BEGIN think_timer.start; Hold(thinktime); think timer.stop; 3065 queue(driverq, THIS consolec, high); switch_context; IF full diags THEN BEGIN Outimage; ptime; Outtext("INPUT FROM CONSOLE #"); Outint(userid,3); END; rt:=Time; pr.c_time:=0; 3075 response_timer.start; Passivate; !wait until processing finished; .response_timer.stop; !accumulate response times; rt:=Time-rt; IF pr.c_time<longtimeslice THEN 3080 !analyse response to trivial command; short_commands.incr; IF rt>2.0&6 THEN over2.incr; IF rt>5.0&6 THEN over5.incr; END ELSE non_trivial.data(pr.c_time,rt); 3085 completed_commands.incr; !another command completed; ``` REF(Head) c\_arrival\_list; ``` IF full_diags THEN BEGIN ptime; Outtext("OUTPUT TO CONSOLE #"); Outint(userid,3); Outimage; END; END; END; END of class consolec; 3095 REF(consolec) ARRAY console(1:max_consoles); PROCEDURE thinking_consoles; 3100 BEGIN INTEGER i,j; Outtext(" NUMBER OF CONSOLES IN THINKING STATE"); FOR i:=1 STEP 1 UNTIL max_consoles DO IF NOT console(i).Idle THEN j:=j+l; 3105 Outint(j,4); Outtext(" NUMBER AWAITING ENTRY TO SYSTEM"); Outint(k(cnsl_site).c_secretary.domain QUA command.c_wait_list.Cardinal,4); Outimage; 3110 END; ``` | Process CLASS clockc(id); INTEGER id; !site it belongs to; BEGIN PROCEDURE and (interval); | 3115 | |---------------------------------------------------------------------------------------------------------|------| | PROCEDURE set(interval); REAL interval; REACTIVATE THIS clockc DELAY interval; | 3113 | | PROCEDURE halt(remaining); NAME remaining; REAL remaining; !time of processors time slice; | 3120 | | IF THIS clockc=/=Current AND NOT THIS clockc.Idle THEN BEGIN !called when want to suspend flow of time; | | | <pre>remaining:=THIS clockc.Evtime-Time; Cancel(THIS clockc); END ELSE remaining:=0;</pre> | 3125 | | WHILE TRUE DO BEGIN INSPECT k(id) DO BEGIN | 3130 | | <pre>queue(driverq,THIS clockc,high); switch_context;</pre> | | | <pre>END; IF full_diags THEN BEGIN Outint(id,2); Outchar('!');</pre> | 3135 | | END;<br>Passivate;<br>END; | | | END of class clocke; | 3140 | ``` REF(disk controllerc) ARRAY dsk(n+1:n+max_disks); Link CLASS disk_buffer; BEGIN !data structure; 3145 !space for data; REF(segmentc) seg; REF(domain incarnationc) inc; !control information; !true when read false when write; BOOLEAN read; END; . 3150 Process CLASS disk_controllerc(id, handler_site, d_secretary); INTEGER id, handler_site; REF(domain_incarnationc) d_secretary; BEGIN 3155 !for messages sent to kernels; REF(Head) sq, !for free buffers: freeq, !for actual disk reads and writes; xferq, !for holding reads until claimed; matchq; 3160 !associated disk; REF(diskc) disk; REF(contentc) message; REF(Link) ptr; REF(disk_buffer) buf; !pointer to current buffer; 3165 PROCEDURE int(m); REF(contentc) m; INSPECT m WHEN disk_rqst DO BEGIN 3170 !required segment has already been read from disk; !and is waiting in matchq; buf:-matchq.Suc; WHILE IF buf == NONE THEN FALSE ELSE buf.seg.key NE key buf:-buf.Suc; IF buf==NONE THEN error("DISK READS OUT OF SEQUENCE") 3175 ELSE BEGIN buf.seg.dest:=rqstor; buf.Into(sq); IF THIS disk_controllerc.Idle THEN ACTIVATE THIS disk_controllerc DELAY 0; 3180 END: !send segment away; END WHEN domain_incarnationc DO 3185 !request to read from disk; BEGIN buf:-freeq.Suc; IF buf=/=NONE THEN BEGIN buf.read:=TRUE; buf.seg:-processor.params(1); !set up information; 3190 buf.inc:-m QUA domain_incarnationc; !and put into fifo queue for disk; buf.Into(xferg); IF disk.Idle THEN disk.transfer; IF NOT freeq.Empty THEN signal_free_buffer; END ELSE error("DISK MANAGEMENT MESSED UP"); 3195 END ``` ``` BEGIN !segment to be written to disk; buf:-freeq.Suc; IF buf=/=NONE THEN BEGIN 3200 buf.read:=FALSE; buf.inc:-NONE; buf.seg:-m QUA segmentc; buf.Into(xferq); 3205 IF disk.Idle THEN disk.transfer; IF NOT freeq.Empty THEN signal_free_buffer; END ELSE error("DISK MANAGEMENT MESSED UP"); END 3210 OTHERWISE error("UNRECOGNISED MESSAGE TO DISK"); PROCEDURE signal_free_buffer; BEGIN !this is only executed when d_secretary is not scheduled; 3215 d_secretary.dest:=handler_site; d_secretary.Into(sq); IF THIS disk_controllerc.Idle THEN ACTIVATE THIS disk_controllerc DELAY 0; !equivalent to send_message(handler_site,d_secretary); 3220 END; PROCEDURE signal_read_complete(buf); REF(disk_buffer) buf; !holding read data; BEGIN !to await incarnation claiming it; buf.Into(matchq); buf.inc.dest:=handler site; !where process base is; buf.inc.Into(sq); IF THIS disk_controllerc.Idle THEN 3230 ACTIVATE THIS disk_controllerc DELAY 0; END of signal_read_complete; sq:-NEW Head; freeq:-NEW Head; xferq:-NEW Head; matchq:-NEW Head; 3235 dsk(id):-THIS disk_controllerc; disk:-NEW diskc(THIS disk_controllerc); FOR w:=1 STEP 1 UNTIL max_disk_bufs DO NEW disk_buffer.Into(freeq); !initialize; ACTIVATE disk DELAY 0; 3240 WHILE running DO BEGIN WHILE sq.Suc =/= NONE DO BEGIN 3245 ptr:-sq.Suc; !of sq; ptr.Out; IF ptr IS disk_buffer THEN message:-ptr QUA disk_buffer.seg ELSE message:-ptr; message.orgn:=id; Hold(message.size*mesdelay); 3250 channel_use.add(message.size); IF message.size=32 THEN control_count.incr; INSPECT k(message.dest) DO int(message); IF ptr IS disk_buffer THEN ``` ``` BEGIN 3255 IF freeq.Empty THEN signal_free_buffer; ptr.Into(freeq); END; END; 3260 !no more messages to send; Passivate; END; END of class disk_controllerc; 3265 contentc CLASS disk_rqst; BEGIN INTEGER rqstor, key; END; 3270 Process CLASS diskc(controller); REF(disk_controllerc) controller; BEGIN REF(disk_buffer) buf; !random number seed; 3275 INTEGER u; REF(timer) idle_timer; REF(counter) transfers, bytes; PROCEDURE transfer; 3280 BEGIN !called by controller to initiate transfer; buf:-controller.xferq.Suc; idle_timer.stop; REACTIVATE THIS diskc DELAY 3285 (Abs(Randint(1,20,u)-Randint(1,20,u))*2000 !find track 2msecs intertrack time; '+Uniform(0,50000,u) !50 msec rotation; +buf.seg.size*2); !O.5 mbytes/sec transfer rate; END; 3290 u := 3031; NEW groupheading("DISK PERFORMANCE"); bytes:-NEW counter("BYTES TRANSFERED"); transfers:-NEW counter("COMPLETED TRANSFERS"); idle_timer:-NEW timer("DISK IDLE TIME", NONE); 3295 idle_timer.start; Passivate; WHILE running DO BEGIN - transfers.incr; 3300 bytes.add(buf.seg.size); IF buf.read THEN controller.signal_read_complete(buf) ELSE BEGIN !write so buffer is free; buf.seg.Into (controller.d_secretary.domain QUA diskhandler.wfreeq); !a big fix to keep number of segment objects constant; IF controller.freeq.Empty THEN controller.signal_free_buffer; buf.Into(controller.freeq); 3310 END; IF controller.xferq.Empty THEN ``` ( BEGIN idle\_timer.start; Passivate; !no more disk transfers to perform; END ELSE transfer; !another segment; END; END of class diskc; 3320 ``` PROCEDURE system initialization; BEGIN INTEGER i; statistic_list:-NEW Head; 3325 grand_t_list:-NEW Head; !initialize statistic lists; total_response:-NEW grand_total("RESPONSE TIMES"); usage :- NEW grand total ("SERVICE TIMES"); NEW groupheading("UTILIZATION OF PROCESSORS"); FOR i:=1 STEP 1 UNTIL n DO 3330 BEGIN NEW groupheading(fillin("SITE",i)); k(i) :- NEW kernelc(i); ACTIVATE k(i); 3335 END: NEW groupheading(""); new_incarnations:-NEV counter("CHANGES OF DOMAIN"); xfered_domains:- NEW counter("TRANSFERED DOMAINS"); xfered_processors:-NEW counter("TRANSFERED PROCESSORS"); xfered_locals:-NEW counter("TRANSFERED LOCAL SEGMENTS"); 3340 migrations:-NEW counter("FORCED MIGRATIONS"); chopcount:- NEW counter("PROCESSORS BLOCKED ON ENTRY TO NETWORK"); spacecount:- NEW counter("INCARNATIONS BLOCKED WAITING FOR SPACE"); 3345 NEW groupheading("RESPONSE TIMES"); short_commands:-NEW counter("COMPLETED SHORT COMMANDS"); over2:- NEW counter("RESPONSE TIMES OVER 2 SECS"); over5:-NEW counter("RESPONSE TIMES OVER 5 SECS"); 3350 non_trivial:- NEW regression("NON TRIVIAL SERVICE TIMES", "RESPONSE TIME"); NEW groupheading("COMMUNICATIONS SUBSYSTEM"); channel_use:-NEW counter("BYTES TRANSFERED"); control_count:-NEW counter("CONTROL MESSAGES (32 BYTES) SENT"); 3355 END: !work variable; INTEGER w; 3360 TEXT PROCEDURE dissect(p); REF(Link) p; !gives a text description of a class; IF p IN contentc THEN dissect:-p QUA contentc.dump ELSE dissect:- Copy(" - LINK - "); 3365 PROCEDURE audit; BEGIN !examines various queues to check on operation of system; INTEGER i,j,size; 3370 REF(Link) ptr; thinking_consoles; FOR i:=1 STEP 1 UNTIL n DO INSPECT k(i) DO BEGIN q_analysis(driverq,fillin("DRIVERQ",i),dissect); 3375 q_analysis(spaceq,"SPACEQ",dissect); size:=0; ``` ``` Outtext("DOMAINS"); Outimage; FOR j:=1 STEP 1 UNTIL fixed_domains DO IF dmn_info(j).here OR dmn_info(j).copy THEN -3380 INSPECT dmn_info(j) DO BEGIN size:=size+d.size; !keep track of all space actually being used; 3385 Outint(j,6); IF here THEN Outtext(" HERE") ELSE Outtext(" COPY"); IF NOT external_segs.Empty THEN BEGIN Outchar('('); 3390 ptr:-external_segs.Suc; WHILE ptr=/=NONE DO BEGIN Outint(ptr QUA domain_incarnationc.processor.pid,3); ptr:-ptr.Suc; 3395 END; Outchar(')'); END; IF NOT work. Empty THEN BEGIN Outtext(" PROCESSOR LIST("); 3400 ptr:-work.Suc; WHILE ptr=/=NONE DO Outint(ptr QUA virtual_processor.pid,3); 3405 ptr:-ptr.Suc; END; Outchar(')'); END; END of looking at domains; 3410 Outimage; Outtext("OUTSTANDING MESSAGES "); Outint ((sq.Cardinal+cq.Cardinal+ (IF s_channel.Idle THEN 0 ELSE 1)),3); 3415 Outimage; FOR i:=1 STEP 1 UNTIL n DO BEGIN Outint(m_use(j),8); Outchar(':'); Outint(qfs(j),2); 3420 Outtext(" ACTUAL FREE MEMORY"); FOR j:=0 STEP 1 UNTIL t_length-1 DO IF seg_table(j)=/=NONE THEN size:=size+seg_table(j).size; Outint(msize-4000-size,8); COPYSPACE"); Outint(copyspace,8); 3425 Outtext(" Outimage; END; Outimage; Outtext("NUMBER QUEUED FOR DISK READS"); 3430 j:=0; FOR i:=1 STEP 1 UNTIL max_disks DO INSPECT k(i*(n//max_disks)).d_secretary.domain WHEN diskhandler DO j:=j+rql.Cardinal+rqh.Cardinal; ``` ``` !could be a transfer in progress; Outint(j,3); Outimage; Eject(Line+6); END; ``` ``` statistic list:-NEW Head; grand_t_list :- NEW Head; !for keeping control of statistics; Eject(Line+4); 3445 SIMULATION OF NETWORK WITH"); Outtext(" Outint(n, IF n<10 THEN 2 ELSE 3); Outtext(" SITES AND WITH"); Outint(max_consoles,3); Outtext(" CONSOLES"); Outimage; Eject(Line+3); 3450 FOR w:= 1 STEP 1 UNTIL 132 DO Outchar('*'); Outimage; Outchar('*'); DIRECTLY CONNECTED SITES AND DISK:"); Outtext(" Outtext(" COPYING OF CODE PERFORMED:"); Outtext(" BIAS TOWARDS PROCESSOR UTILIZATION"); Image.Setpos(132); Outchar('*'); Outimage; 3455 Outtext("* PERIOD OF SIMULATION (SECS) ="); Outfix(sim_time, 0, 4); Outtext(" NUMBER OF SYSTEM DOMAINS ="); 3460 Outint(fixed_domains,3); Outtext(" NUMBER OF COMPILERS ="); Outint(compl,2); Image. Setpos(132); Outchar('*'); Outimage; Outtext("* MEMORY SIZE ="); Outint(msize,7); SIZE DIVIDER CONSTANT="); Outint(size divider,5); Outtext("BYTES Outtext(" LOAD SHEDDING FACTOR="); Outint(load_shed,2); Outtext(" MAXIMUM MIGRATIONS="); Outint(max_shifts,2); Image.Setpos(132); Outchar('*');Outimage; Outtext("* LARGE DOMAINS NOT ALLOWED TO START WHEN"); 3470 Outtext(" GREATEST FREE MEMORY IS LESS THAN "); Outint(chopsize,8); Outtext(" OR NUMBER IN SYSTEM IS GREATER THAN "); Outint(chopfactor, 2); Image.Setpos(132); Outchar('*');Outimage; Outtext("* CONSOLE CONTROL SITE="); Outint(cnsl_site,2); 3475 Outtext(" NUMBER OF DISKS="); Outint(max_disks,2); Outtext(" DISK BUFFERS="); Outint(max_disk_bufs,2); Outtext(" DISK SITE(S)="); FOR w:=1 STEP 1 UNTIL max_disks DO 3480 Outint(w*(n//max_disks),3); Image. Setpos(132); Outchar('*'); Outimage; Outtext("* TIME SLICE ="); Outfix(timeslice*1&-3,0,3); LONG TIME SLICE ="); Outtext("MSECS: Outfix(longtimeslice*1&-3,0,4); 3485 COMMUNICATION FREQUENCY (MHZ) ="); Outtext("MSECS. Outfix(8/mesdelay, 2, 5); RANDOM NUMBER SEED ="); Outint(random_seed,5); Outtext(" Image. Setpos(132); Outchar('*'); Outimage; 3490 FOR w:=1 STEP 1 UNTIL 132 DO Outchar('*'); Outimage; 3495 system initialization; ipl; ``` Hold(settle time \* &6); ``` clearstatistics; Outtext("START OF RUN"); thinking_consoles; 3500 IF full_diags THEN audit; IF running THEN Hold(sim_time*&6); Outtext("END OF RUN"); thinking_consoles; !a check that system has not seized up; IF running THEN BEGIN 3505 outputstatistics; Outtext("PERFORMANCE MEASURE"); Outfix(total_response.total/usage.total,2,8); Outimage; Outtext("FRACTION USEFUL PROCESSOR UTILIZATION"); 3510 Outfix(usage.total/(n*sim_time),3,6); Outimage; END; !of simulation block; END; 3515 results.Close; !of program; END; ``` # CROSS REFERENCE TABLE | a . | 1360 | 1363 | 1387 | 1391 | 1806 | 1808 | 1823 | 1824 | 2317D | 2324D | |--------------|--------|--------|-------|-------|-------|-------|---------|-------|-------|-------| | | 2534d | 2545 | 2581M | 2582M | 2693 | 4.000 | | | 23275 | | | a0 · | 459D | 470 | 471 | 482 | | | | | | | | al | 459D | 469 | 471 | 481 | | | | | | | | abs | 3285 | | | | | | | | | | | action trans | 1441 | 1451D | 1743 | | | | | | | | | active proce | 2891D | 2914 | 2918 | 2924M | 2941M | 2946M | 2952M | 2968N | | | | add' | 327D | 373 | 428D | 790D | 804 | 827 | 3013 | 3251 | 3300 | | | add seg | 554 | 824D | 868 | 1370 | 1392 | | - | | | | | audit | 196 | 3366D | 3500 | | | | | | | | | ь | 2534D | 2545 | 2583M | 2584M | | | | | | | | big d size | 1088D | 1106 | 1152 | | | | | | | | | big p size | 1088D | 1121 | 1153 | 1156 | | | | | | | | blanks | 173 | 184 | 194 | 209 | | | | | | | | breakoutimag | 107 | 120 | | | | | | | | | | bring_togeth | 1066 | 1339D | | | | | | | | | | broadcast | 916D | 985 | 992 | 1764 | | | | | | | | buf | 3163D | 3171 | 3172M | 3173M | 3174 | 3176 | 3177 | 3186 | 3187 | 3188 | | | 3189 | 3190 | 3191 | 3199 | 3200 | 3201 | 3202 | 3203 | 3204 | 3222D | | | 3225 | 3226 . | 3228 | 3274D | 3282 | 3288 | 3300 | 3302M | 3304 | 3309 | | bytes | 3277D | 3293 | 3300 | | | | | | | | | b_entries | 236D | 237 | 1686 | | | | | | | | | cancel | 3126 | | | | • | • | | | | | | cardinal | 232 | 237M | 1107M | 2855M | 3108 | 3413M | 3434M | | | | | change_value | 386D | 626 | 665 | 708 | | | | | | | | channel_busy | 897D | 905 | 929 | 1840 | | | | | | | | channel_use | 2991D | 3013 | 3251 | 3353 | | | | | | | | choice | 1060 | 1061 | 1147 | 1161 | 1170 | 1224 | 1998D | | | | | chopcount | 569D | 2917 | 3342 | | | | | | | | | chopfactor | 93D | 151 | 152 | 2914 | 2918 | 2946 | 3473 | | | | | chopsize | 93D | 154 | 982 | 3471 | | | | | | | | claim | 647D | 689 | 720 | 736 | 1261 | 1758 | 2210 | 3057 | | | | clear | 291D | 300D | 313D | 358D | 395D | 417D | 451D | 517 | 522 | 2972 | | clearstatist | 512D | 3498 | | | | | | | | | | clockc | 589 | 620 | 1676 | 3112D | 3117 | 3122M | 3125 | 3126 | 3131 | | | close | 3515 | • | | | | | | | | | | cnsl_site | 86D | 130 | 2387 | 3050 | 3055 | 3107 | 3475 | • | | | | coming | 1053 | 1091 | 1252 | 1282 | 1287 | 1401 | 1725 | 1756 | 1768 | 1933D | | | 1957 | | | | | | | | | | | command | 2387 | 2886D | 3108 | | | | | | | | | commandn | 84D | 129 | 2387 | 3051 | | | | | | | | compiler | 2393 | 2530D | | | | _ | | | | | | comp1 | 60D | 134 | 135 | 2392 | 2906 | 3461 | | | | | | completed_co | 3040D | 3053 | 3086 | | | | | | | | | console | 2401 | 2402 | 2937 | 3097D | 3104 | | | | | | | consolec | 1705 | 2401 | 2964 | 3035D | 3065 | 3097 | | | | ` | | contentc | 530D | 546 | 606 | 633 | 859 | 861 | 900 | 919 | 927 | 1831 | | | 1838 | 1964 | 1973 | 1984 | 2312 | 2321 | 2727 | 2730 | 3000 | 3003 | | | 3161 | 3166 | 3266 | 3363M | • | | | | | | | contents | 899D | 903 | 904 | 906M | 907 | 911 | 912 | 916D | 923 | 926D | | | 931 | 932 | 935 | 937 | 938 | | | | | | | contextdelay | 65D | 110 | 1619 | 2937 | | | | | | | | controller | 3271D | 3282 | 3302 | 3305 | 3307 | 3308 | 3309 | 3311 | | | | control_coun | 2992D | 3014 | 3252 | 3354 | | | | | | | | сору | 115 | 116 | 117 | 118 | 539 | 758 | 1053 | 1175 | 1253 | 1282 | | | 1472 | 1481 | 1519 | 1881 | 1931D | 1956 | 1978 | 2043 | 2133 | 2418 | | | 2502 | 2540 | 3364 | 3380 | | | | | | | | copyspace | 593D | 663 | 707 | 749 | 1473M | 1520M | 3425 | | | | | cost_formula | 1071D | 1078 | 1152 | 1156 | 1159 | 200 | 100: | | | | | count | . 312D | 314 | 320M | 321 | 325M | 329M | 1281 | 1283 | 1346 | 1349 | | | 1354m | 1359m | 1373M | 1386M | 1401 | 1785 | 1878M | 1880 | 2023D | | | counter | 310D | 562 | 2991 | 2992 | 3040 | 3053 | 3277 | 3293 | 3294 | 3337 | | | 3338 | 3339 | 3340 | 3341 | 3343 | 3345 | 3347 | 3348 | 3349 | 3353 | | | 3354 | 0000 | 0.54 | 1006 | 10000 | 2412 | | | | | | cq | 617 | 895D | 906 | 1836 | 1838M | 3413 | | | | | | create_secre | 2201D | 2873 | 2983 | 1445 | 1615 | | | | | | | cu | 579D | 1638 | 1640 | 1642 | 1645 | 1653 | 1660 | 1664 | 1679 | 1680 | | | 1681 | 1682 | 1683 | 1684 | 1685 | 1687 | 1690M | 1694 | 1695 | 1697 | | | 2182 | 2198 | 00545 | 2252 | 2011 | 2162 | | | | | | current | 2117 | 2118 | 2256D | 2259 | 2916 | 3122 | | | | | | c_arrival_li | 1714 | 2962 | 2972 | 2987 | 3031D | 005: | 2005 | 014- | | | | c_secretary | 582D | 1707 | 1711 | 1712 | 2983 | 2984 | 2985 | 3107 | | | | c_size | 2163D | 2169 | 2516 | 2860 | 2981 | 0.50- | 0.5.5.5 | | | | | c_time | 1584 | 1585 | 1681 | 2234D | 3073 | 3080 | 3085 | | | | | c_wait_list | 2890D | 2915 | 2916 | 2920 | 2945 | 2950 | 2988 | 3108 | | | | d | 459D | 468 | 469 | 470 | 473 | 485 | 865 | 1075D | 1076 | 1077M | | | 1078 | 1105 | 1106 | 1145 | 1231 | 1297 | 1313 | 1419 | 1459 | 1465 | | | | | | | | | | | | | | | | | | | | | • | | | | |---------------------------|----------------|----------------|---------------|---------------|---------------|---------------|----------------|----------------|---------------|--------------| | data | 1473<br>443D | 1486<br>3085 | 1503 | 1510 | 1520 | 1521 | 1522 | 1929D | 3383 | | | db size | 2164D | 2169 | 2517 | 2860 | 2981 | | | | | | | dd <del>'</del> I | 61D | 135 | 136 | 2394 | 2911 | | | | | | | ddu . | 61D | 136 | 137 | 2394 | 2489 | 2908 | | | | | | deadlock_war | 598D | 726 | 730 | 1898 | 1907 | | | | | | | default | 550D | 2035 | 2087 | 2140 | 2299 | . 2370M | | | | | | delete_domai | 770<br>832D | 1486<br>1846 | 1510 | 1515D | 2625 | 2644 | | | | | | delete_seg<br>desc | 82D | 119 | 2089<br>2374 | 2552<br>2573 | 2635<br>2629 | 2644 | | | | | | dest | 534D | 899D | 901 | 904M | 3015 | 2752<br>3017 | 3019 | 3176 | 2215 | 2227 | | | 3253 | | 701 | 704.1 | 3013 | 3017 | 3013 | 3170 | 3215 | 3226 | | did | 1049 | 1087 | 1105 | 1231M | 1237 | 1249 | 1252M | 1253 | 1266 | 1279 | | | 1285m | 1296 | 1297 | 1313 | 1347 | 1401 | 1402 | 1416 | 1419 | 1441 | | | 1486 | 1503 | 1506 | 1510 | 1515D | 1518 | 1687 | 1721 | 1723 | 1725M | | | 1727 | 1730 | 1736 | 1743 | 1753 | 1763 | 1798 | 1861 | 1867 | 1966D | | | 1973d<br>2209 | 1992d<br>2213 | 2033<br>2261D | 2045<br>2266M | 2061D<br>2268 | 2101M<br>2269 | 21'34<br>2331D | 2139 | 2146D | 2154 | | | 2450 | 2468 | 2482 | 2489M | 2504 | 2517 | 2519 | 2340<br>252611 | 2372M<br>2586 | 2420<br>2649 | | | 2657 | 2871 | 2980 | 2.05 | 2304 | 2317 | 2317 | 232011 | 2300 . | 2049 | | didn | 2028D | 2033 | | | | | | | | | | disk | 2661D | 2727 | 2730 | 2777 | 2787 | 2868 | 2877 | 3160D | 3192M | 3205M | | 4.41 | 3236 | 3239 | 20715 | | | | | | | | | disko<br>diskhandler | 3160<br>2389 | 3236<br>2661D | 3271D | 3284 | • | | | | | | | diskhandlern | 2434 | 2561 | 3305<br>2574 | 3433<br>2604 | 2639 | 2881D | 2884 | | | | | diskl | 61D | 139 | 2389 | 2884 | 2037 | 20015 | 2004 | | | | | disk_buffer | 3143D | 3163 | 3223 | 3238 | 3247M | 3254 | 3274 | | | | | disk_control | 2877 | 3141 | 3151D | 3178 | 3179 | 3217 | 3218 | 3229 | 3230 | 3235 | | | 3236 | 3272 | • | | | | | | | | | disk_read | 1374 | 1376 | 1377 | 2290D | 2307 | | | | | | | disk_rqst<br>disk write r | 2290<br>2684D | 2307<br>2693 | 3168<br>2695 | 3266D | 2060 | | | | | | | dissect | 1629 | 3360D | 3363 | 2867<br>3364 | 2868<br>3375 | 3376 | | | | | | dmn info | 630 | 758 | 759 | 760 | 761 | 763 | 764 | 865 | 1031D | 1049 | | | 1087 | 1105 | 1231M | 1237 | 1249 | 1252M | 1253 | 1266 | 1279 | 1296 | | | 1297 | 1313 | 1347 | 1401 | 1402 | 1416 | 1419 | 1441 | 1503 | 1506 | | | 1518 | 1687 | 1721 | 1723 | 1725M · | 1727 | 1730 | 1743 | 1753 | 1798 | | dmm 1-6 | 1871 | 1880 | 1881 | 3380M | 3381 | | | | | | | dmn_infoc<br>dmn rqst | 630<br>1034D | 1031<br>1041 | 1452<br>1047M | 1925D | 1054 | 1055 | 1050 | 10/0 | | | | dian_rqst | 1054D<br>1066m | 1041<br>1082d | 10478 | 1049<br>1095 | 1054<br>1173 | 1055<br>1176 | 1058 | 1060 | 1061M | 1063 | | | 1292 | 1339d | 1343 | 1402 | 1403 | 1170 | 1199 | 1211D | 1214 | 1225 | | dmn_transfer | 1719 | 1964D | 2287 | 2304 | 2.00 | | | | | | | domain | 1419 | 1421 | 1423 | 1494D | 1500 | 1501 | 1503 | 1506 | 1571 | 1598 | | | 1599 | 1600 | 1601 | 1602 | 1680 | 1994D | 2214 | 3107 | 3305 | 3432 | | domaine | 865 | 1495 | 1750 | 184411 | 1929 | 1994 | 2061D | 2142 | 2161 | 2214 | | domain copy | 2407<br>1494D | 2530<br>1844 - | 2589 | | - | | | | - | • | | domain incar | 579 | 678 | 703 | 872 | 873 | 932 | 1035 | 1083 | 1212 | 1207 | | <del></del> | 1340 | 1410 | 1437 | 1544 | 1633 | 1755 | 1858 | 1984D | 1212<br>2073 | 1307<br>2080 | | • | 2096 | 2111 | 2112 | 2124 | 2191 | 2203 | 2250 | 2256 | 2261 | 2275 | | | 2301 | 2414 | 2429 | 2442 | 2463 | 2474 | 2498 | 2513 | 2536 | 2549 | | | 2571 | 2595 | 2609 | 2618 | 2672 | 2735 | 2748 | 2792 | 2799 | 2895 | | do domain ca | 2901<br>1055 | 2935 | 2958 | 3146 | 3153 | 3184 | 3190 | 3393 | | | | dp_domarn_ca | 2154 | 1082D<br>2158D | 2269 | | | | | | | | | dr | 1755D | 1772 | 1773 | 1779 | 1780 | 1784 | 1785 | 1787 | 1788 | 1700 | | draw | 2431 | 2448 | 2627 | | 1,00 | 1704 | 11,62 | 1707 | 1700 | 1790 | | driverq | 576D | 610 | 723 | 870 | 874 | 878 | 882 | 912 | 1309 | 1323 | | | 1426 | 1429 | 1623 | 1686 | 1690 | 1695 | 1711 | 1773 | 2106 | 2194 | | 3 = 1. | 2716 | 2920 | 2950 | 2966 | 3022 | 3065 | 3131 | 3375 | | | | dsk<br>dump | 3019<br>531D | 3141D<br>538D | 3235 | 602 | 10770 | 1070 | | | | | | d damp | 2355d | 2356 | 539<br>3363 | 693 | 1977D | 1978 | 2039D | 2046 | 2130D | 2135 | | dumpv | 2042D | 2043 | 2044 | 2045 | 2046 | | | | | | | d cost | 1089D | 1152 | 1161M | 20.5 | 2040 | | | | | | | d_id | 2337D | 2340 | | | | | | | | | | d_loc | 1054 | 1176 | 1347 | 1727 | 1731 | 1766 | 1798 | 1940D | | | | d_loc_update | 1736 | 1763 | 1796 | 1952 | 1973D | | | | | | | d_secretary<br>d site | 581Đ | 2873 | 2874 | 2875 | 2877 | 3151D | 3215 | 3216 | 3305 | 3432 | | d_site<br>d_size | 1104<br>1105 | 2012D<br>1107 | 1108 | 1240 | 1254 | 1270 | 1210 | 2017- | | | | d_size<br>d_transfer | 1285 | 1286 | 1347 | 1240<br>2287D | 1 254<br>2304 | 1270 | 1318 | 2014D | | | | eject | 505 | 3438 | 3444 | 3448 | -307 | | | | | | | empty | 224 | 242 | 759 | 760 | 1197 | 1467M | 1484M | 1508 | 1509 | 1770 | | | 1836m | 1838 | 2697M | 2700 | 2707 | 2725M | 2726 | 2729 | 2754 | 2816M | | | 2830m | 2832m | 2841 | 2846 | 2915 | 2945 | 3193 | 3206 | 3256 | 3307 | | entry | 3311<br>249D | 3387<br>252 | 3398 | | | | | | | | | J, | 2470 | 4.J.L | | | | | | | | | | erlang | 2556 | | | 2.0 | | | 1570 | 1506 | 17/6 | | |------------------|---------------------|-----------------|----------------|---------------|----------------|---------------|----------------|----------------|---------------|--------------| | error | 1870 | 254 | 801 | 818 | 820 | 1422 | 1572 | 1596 | 1746 | 1761 | | | 1875 | 1917 | 2247<br>1600 | 2273<br>1601 | 2280<br>1603D | 3174 | 3194 | 3207 | 3210 | | | esac ,<br>evtime | 1598<br>3125 | 1599 | 1000 | 1001 | 10030 | | | | | | | examine choi | 1063 | 1211D | | | | | | | | | | execute | 1543D | 1645 | | | | | | | | | | external_seg | 760 | 1107 | 1197 | 1402 | 1467 | 1484 | 1509 | 1779 | 1871 | 1946D | | _ | 1955 | 3387 | 3390 | 70511 | 105/11 | 105614 | 1000 | 10/1 | 20010 | | | extra_space | 684 | 688M | 720 | 735M | 1254M<br>2268 | 1256M<br>2269 | 1260<br>2271 | 1261<br>2279 | 2021D<br>2301 | 2966 | | e_stack<br>f | 1861<br>1755D | 2250D<br>1784 | 2259<br>1790 | 2266<br>1858D | 1871 | 1872M | 1873M | 1875 | 1878M | 1880 | | 1 | 1883 | 1884 | 1770 | 10300 | 10/1 | 10,211 | 10, 311 | 10/3 | 1070.1 | 1000 | | fetch c | 2076 | 2213 | 2261D | 2271 | 3051 | | | | | | | fillin | 202D | 213 | 728 | 801 | 2273 | 2280 | 2356 | 2598 | 2739 | 3046 | | | 3332 | 3375 | | | | | | | | | | finisht | 1570D | 1577 | 1585 | 1586 | 1/00 | | | | · | | | first | 221D | 225M | 715 | 725<br>629 | 1623<br>757 | 864 | 1031 | 2158 | 2298 | 3379 | | fixed_domain | 52D<br><b>3</b> 460 | 140 | 553 | 029 | 131 | 004 | 1031 | 21 70 | 2230 | 3317 | | format | 2149D | 2152D | 2269 | 2487D | 2524D | 2654D | | | | | | formatc | 2146D | 2154 | 2158 | 2485 | 2522 | 2652 | 2871 | 2980 | | | | found | 1308D | 1321 | 1329 | | | | | | | | | freeq | 3156D | 3186 | 3193 | 3199 | 3206 | 3233 | 3238 | 3256 | 3257 | 3307 | | | 3309 | 140 | 106 | 602 | 2416 | 2451 | 2465 | 2500 | 2520 | 2597 | | full_diags | 73D | 168<br>3067 | 196<br>3088 | 692<br>3134 | 2416<br>3500 | 2451 | 2465 | 2500 | 2538 | 2391 | | going | 2737<br>761 | 1472 | 1485 | 1507 | 1937D | | | | | | | gone | 1219D | 1226 | 1245 | 1279 | 2,3,2 | | | | | | | grand_total | 334 | -414D | 432 | 560 | 3327 | 3328 | | | | | | grand_t_list | 295D | 432 | 506 | 520 | 3325 | 3442 | | | | | | groupheading | 297D | 3046 | 3292 | 3329 | 3332 | 3336 | 3346 | 3352 | 1470 | 1401 | | h | 1451D | 1458 | 1459M<br>1486 | 1460<br>1487 | 1463M | 1465 | 1467M | 1472H | 1473 | 1481 | | halt | 1484m<br>1653 | 1485<br>3119D | 1400 | 1407 | | | | | | | | handler site | 3151D | 3215 | 3226 | | | | | | | | | hash | 785D | 787 | 794 | 811 | | | | | | | | head | 219 | 246 | 294 | 295 | 617 | 618 | 895 | 1943 | 1955M | 2176 | | | 2220 | 2679 | 2681 | 2683 | 2861 | 2862 | 2863 | 2864 | 2865 | 2866 | | | 2890<br>3442 | 2987 | 2988 | 3031 | 3155 | . 3233М | 3234 | 3324 | 3325 | 3441 | | heading | 257D | 267 | 289D | 304 | 319 | 369 | 404 | 423 | 462 | 476 | | heading2 | 437D | 463 | 477 | | | | | | | | | here | 1053 | 1231 | 1237 | 1252 | 1266 | 1282 | 1296 | 1458 | 1463 | 1725 | | | 1769 | 1880 | 1935D | 1958 | 3380 | 3386 | | | | | | high | 80D | 114 | 118 | 219 | 223 | 232 | 242 | 243 | 246 | 251 | | • | 271<br>2194 | 723<br>2920 | 870<br>2950 | 878<br>2966 | 882<br>3022 | 912<br>3065 | 1323<br>3131 | 1695 | 1773 | 2106 | | hk | . 793D | 794 | 795 | 798 | 799M | 801 | 803 | 804 | 810D | 811 | | • | 812 | 814 | 815M | 817 | 820 | 821 | | -•- | | | | hold | 652 | 691 | 705 | 755 | 1045 | 1580 | 1619 | 3063 | 3250 | 3497 | | | 3501 | | | | | | | | | | | i | 202D | 211 | 220D | 223 | 224M | 225M | 232M | 241 | 242M | 243 | | | 246m<br>761 | 264d<br>763 | 271<br>764 | 273<br>765 | 274<br>793D | 753D<br>798 | 757<br>799 | 758<br>801 | 759<br>810D | . 760<br>814 | | | 815 | 817 | 836D | 837 | 838 | 841 | 921D | 922 | 923M | 1009D | | | 1012 | 1013 | 1015 | 1017 | 1018 | 10900 | 1115 | 1116 | 1117 | 1118M | | | 1119 | 1128 | 1129 | 1130 | 1131 | 1134 | 1136 | 1220D | 1345D | 1356 | | | 1357 | 1360m | 1363 | 1368 | 1370M | 1372 | 1376 | 1377 | 1382 | 1383 | | | 1385 | 1387m | 1391 | 1392M | 1804D | 1806M | 1808 | 1818D | 1822 | 1823 | | | 1824<br>2087 | 2026d ·<br>2089 | 2034<br>2100 - | 2035M<br>2101 | 2051<br>3101D | 2052<br>3103 | 2070D<br>3104 | 2082D<br>3323D | 2083<br>3330 | 2084<br>3332 | | | 3333m | 3334 | 3369D | 3372 | 3373 | 3375 | 3431 | 3432 | 3330 | 3332 | | id | 573D | 616 | 620 | 625 | 663 | 670 | 694 | 707 | 711 | 728 | | | 801 | 829 | 839 | 879M | 901 | 903 | 911 | 923 | 931 | 932H | | | 935 | 984 | 992 | 1060 | 1104 | 1147 | 1152 | 1153 | 1154 | 1155 | | | 1158 | 1161 | 1170 | 1197 | 1198 | 1240 | 1257 | 1258 | 1270 | 1271 | | | 1286<br>1729 | 1319<br>1752 | 1352<br>1763 | 1355<br>1766 | 1374<br>1897 | 1385<br>1903 | 1395<br>2951 M | 1397<br>2969M | 1413<br>3112D | 1628<br>3130 | | | 3135 | 3151d | 3235 | 3249 | 107/ | 1903 | ~ 7 J 1 F1 | 2 70 JH | J114D | 2120 | | idle | 1530 | 3104 | 3122 | 3178 | 3192 | <b>320</b> 5 | 3217 | 3229 | 3414 | | | idle_timer | 603D | 621 | 1910 | 1912 | 3276D | 3283 | 3295 | 3296 | 3313 | | | iflag | 586D | 614 | 1535 | 1586 | 1590 | 1617 | 1620 | 1660 | | | | image | 3455 | 3462 | 3468 | 3474 | 3481 | 3488 | 1/1/ | 1/1/ | 1/10 | 1.40 | | inc | 677D<br>1423 | 684N<br>1425 | 688H<br>1426 | 693<br>1429N | 1409D<br>1436D | 1413<br>1440 | 1414<br>1441 | 141621<br>1443 | 1419M<br>1445 | 1421<br>1447 | | | 1423<br>2191d | 2192 | 2193 | 219411 | 3146D | 3190 | 3202 | 3226 | 3228 | 1447 | | incore | 82D | 119 | 553 | 828 | 1116 | 1129 | 1357 | 1383 | 2084 | 2140 | | | 2299 | 2374 | 2551 | 2627 | 2634 | 2643 | ~ | | | | | incr | 324D | 696 | 1228 | 1499 | 1809 | 1820 | 1825 | 2108 | 2917 | 3014 | | | 3082 | 3083 | 3084 - | 3086 | 3252 | · 3299 | | | | | |-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------|----------------------------------------------|--------------------------------------| | inint | 108 | 121 | | | | | | | | | | initializati | 608D | 1612 | | | | | | | | | | initial_time | . 383D | 399 | 405 | 406 | | | | | | | | initiate | 938 | 3002D | 2010 | 2027 | 2020 | | | | | | | initiate_rea<br>int | 2722D<br>858D | 2725<br>2142 | 2819<br>3017 | 2834<br>3019 | 2839 | 2252 | | | | | | interdmn jum | 2076 | 2091 | 2095D | 3019 | 3165D | 3253 | | | | | | interdomain | 2073D | 2434 | 2456 | 2561 | 2574 | 2604 | 2639 | 2909 | | | | interval | 3115D | 3117 | 2430 | 2301 | 2374 | 2004 | 2033 | 2303 | | | | into | 252 | 292 | 432 | 906 | 1095 | 1249 | 1402 | 1416 | 1714 | 2182 | | | 2703 | 2709 | 2757 | 2766 | 2767 | 2782 | 2870 | | 3177 | 3191 | | | 3204 | 3216 | 3225 | 3228 | 3238 | 3257 | 3304 | 3309 | | • | | ipl | 2381D | 3496 | | | | | | | | | | ipld | 55D | 132 | 135 | 2392M | 2906M | | | | | | | items | 257D | 278 | | | | | | | | | | i_chopf | 95D | 152 | 1270 | 1318 | | | | | | | | j | 753D | 765 | 769 | 770 | 960D | 976 | 978M | 979M | 1009D | 1011 | | | 1017 | 1021 | 2382D | 3101D | 3104M | 3105 | 3369D | 3379 | 3380M | 3381 | | 1. | 3385 | 3416 | 3417 | 3419 | 3422 | 3423M | 3430 | 3434M | 3436 | 0100 | | k | 553<br>2189 | 559D<br>2198 | 1009D<br>2207 | 1010<br>2374 | 1011M | 1013<br>2634 | 2089 | 2103 | 2142 | 2182 | | | 2730 | 2787 | 2812 | 2872 | 2552<br>2914 | 2918 | 2644<br>2920 | 2694<br>2925M | 2716<br>2942 | 2727 | | | 2947 | 2949 | 2965 | 2982 | 3017 | 3021 | 3055 | 3107 | 3130 | 2943M<br>3253 | | | 3333 | 3334 | 3373 | 3432 | 3017 | 3021 | 5055 | 3107 | 3130 | 3433 | | keeping | 341D | 344 | 346 | 352 | 354 | 361 | 370 | 376 | | | | kernelc | 559 | 573D | 1530 | 1537 | 3333 | | | | | | | key | 549D | 553 | 785D | 787M | 790D | 794 | 803 | 807D | 811 | 812 | | • | 815 | 827 | 837 | 864 | 865 | 1360 | 1376M | 1387 | 2139 | 2298 | | | 2305 | 2341 | 2350 | 2369M | 2375 | 2693 | 3172M | 3268D | | | | 1 | 2152D | 2487D | 2489 | 2524D | 2526 | 2654D | 2657M | | | | | lasttime | 763 | 764 | 1487 | 1951D | | | | | | | | length | 209 | 211 | | | | | | | | | | level | 386D | 390 | | | | | | | | | | lfrom | 2360D | 2365 | 2378 | 2//0 | | | | | ٠ | | | line | 505 | 3438 | 3444 | 3448 | | | | | | | | linear | 2545<br>221 | 2601<br>250 | 264 - | 289 | 530 | 1610 | 2685 | 3143 | 2162 | 2261 | | link | 3370 | 250 | 204 | 209 | 230 | 1010 | 2003 | 3143 | 3162 | 3361 | | linkage | 2961 | | | | | | | | | | | load shed | 89D | 149 | 1240 | 1270 | 3466 | | | | | | | locals | 1129 | 1130 | 1131 | 1134 | 1136 | 1383 | 1385 | 1387 | 1392M | 1996D | | | 2035m | 2052 | 2084 | 2087 | 2089 | 2269 | 2476 | 2611 | | | | local data | 2007D | 2545 | 2554 | 2559N | 2601 | 2619 | 2624M | | | | | local_seg | | | | | 2152 | 2236 | 2303 | 2328D | 2361 | 2488 | | | 1865 | 1867 | 1996 | 2052 | 2152 | | 2303 | 23200 | 2301 | 2400 | | _ 0 | 1865<br>2525 | 2655 | 2702 | 2756 | 2870 | | 2303 | 23200 | 2301 | | | -<br>longtimeslic | 2525<br>68D | 2655<br>112 | 2702<br>1681 | 2756<br>1682 | 2870<br>3080 | 3484 | | | | | | _ | 2525<br>68D<br>80D | 2655<br>112<br>114 | 2702<br>1681<br>115 | 2756<br>1682<br>219 | 2870<br>3080<br>224 | 3484<br>225 | 232 | 237 | 241 | 246 | | longtimeslic<br>low | 2525<br>68D<br>80D<br>251 | 2655<br>112<br>114<br>271 | 2702<br>1681<br>115<br>685 | 2756<br>1682<br>219<br>1309 | 2870<br>3080 | 3484 | | | | | | longtimeslic<br>low | 2525<br>68D<br>80D<br>251<br>754D | 2655<br>112<br>114<br>271<br>756 | 2702<br>1681<br>115<br>685<br>763 | 2756<br>1682<br>219<br>1309<br>764 | 2870<br>3080<br>224<br>1683 | 3484<br>225<br>2705 | 232<br>2766 | 237<br>2782 | 241 | | | longtimeslic<br>low<br>lru<br>lto | 2525<br>68D<br>80D<br>251<br>754D<br>2360D | 2655<br>112<br>114<br>271<br>756<br>2366 | 2702<br>1681<br>115<br>685<br>763<br>2367 | 2756<br>1682<br>219<br>1309<br>764<br>2368 | 2870<br>3080<br>224 | 3484<br>225 | 232 | 237 | | | | longtimeslic low 1ru 1to 1 cost | 2525<br>68D<br>80D<br>251<br>754D<br>2360D<br>1089D | 2655<br>112<br>114<br>271<br>756<br>2366<br>1159 | 2702<br>1681<br>115<br>685<br>763<br>2367<br>1161 | 2756<br>1682<br>219<br>1309<br>764<br>2368<br>1162 | 2870<br>3080<br>224<br>1683<br>2369 | 3484<br>225<br>2705<br>2370 | 232<br>2766 | 237<br>2782 | 241 | | | longtimeslic low lru lto l_cost l_seg_list | 2525<br>68D<br>80D<br>251<br>754D<br>2360D<br>1089D<br>1387 | 2655<br>112<br>114<br>271<br>756<br>2366<br>1159<br>1391 | 2702<br>1681<br>115<br>685<br>763<br>2367<br>1161<br>1397 | 2756<br>1682<br>219<br>1309<br>764<br>2368<br>1162<br>1398 | 2870<br>3080<br>224<br>1683<br>2369<br>2289D | 3484<br>225<br>2705<br>2370<br>2306 | 232<br>2766 | 237<br>2782 | 241 | | | longtimeslic low 1ru 1to 1 cost 1 seg_list 1 seg_listc | 2525<br>68D<br>80D<br>251<br>754D<br>2360D<br>1089D<br>1387<br>1801 | 2655<br>112<br>114<br>271<br>756<br>2366<br>1159<br>1391<br>2289 | 2702<br>1681<br>115<br>685<br>763<br>2367<br>1161<br>1397<br>2306 | 2756<br>1682<br>219<br>1309<br>764<br>2368<br>1162<br>1398<br>2321D | 2870<br>3080<br>224<br>1683<br>2369<br>2289D<br>2684 | 3484<br>225<br>2705<br>2370<br>2306<br>2867 | 232<br>2766<br>2371 | 237<br>2782<br>2372 | 241<br>2375 | 246 | | longtimeslic low lru lto l_cost l_seg_list | 2525<br>68D<br>80D<br>251<br>754D<br>2360D<br>1089D<br>1387 | 2655<br>112<br>114<br>271<br>756<br>2366<br>1159<br>1391 | 2702<br>1681<br>115<br>685<br>763<br>2367<br>1161<br>1397 | 2756<br>1682<br>219<br>1309<br>764<br>2368<br>1162<br>1398 | 2870<br>3080<br>224<br>1683<br>2369<br>2289D | 3484<br>225<br>2705<br>2370<br>2306 | 232<br>2766 | 237<br>2782 | 241 | | | longtimeslic low 1ru 1to 1 cost 1 seg_list 1 seg_listc | 2525<br>68D<br>80D<br>251<br>754D<br>2360D<br>1089D<br>1387<br>1801<br>1100 | 2655<br>112<br>114<br>271<br>756<br>2366<br>1159<br>1391<br>2289<br>1130 | 2702<br>1681<br>115<br>685<br>763<br>2367<br>1161<br>1397<br>2306<br>1138 | 2756<br>1682<br>219<br>1309<br>764<br>2368<br>1162<br>1398<br>2321D<br>1154 | 2870<br>3080<br>224<br>1683<br>2369<br>2289D<br>2684<br>1157 | 3484<br>225-<br>2705<br>2370<br>2306<br>2867<br>1158H | 232<br>2766<br>2371 | 237<br>2782<br>2372 | 241<br>2375 | 246 | | longtimeslic<br>low lru lto l_cost l_scg_list l_seg_listc l_site | 2525<br>68D<br>80D<br>251<br>754D<br>2360D<br>1089D<br>1387<br>1801<br>1100<br>1395m | 2655<br>112<br>114<br>271<br>756<br>2366<br>1159<br>1391<br>2289<br>1130<br>1398 | 2702<br>1681<br>115<br>685<br>763<br>2367<br>1161<br>1397<br>2306<br>1138<br>2012D | 2756<br>1682<br>219<br>1309<br>764<br>2368<br>1162<br>1398<br>2321D<br>1154 | 2870<br>3080<br>224<br>1683<br>2369<br>2289D<br>2684<br>1157 | 2370<br>2306<br>2867<br>1158H | 232<br>2766<br>2371 | 237<br>2782<br>2372 | 241<br>2375 | 246 | | longtimeslic low lru lto l_cost l_scg_list l_seg_listc l_site l_size | 2525<br>68D<br>80D<br>251<br>754D<br>2360D<br>1089D<br>1387<br>1801<br>1100<br>1395m<br>1102<br>858D<br>878 | 2655<br>112<br>114<br>271<br>756<br>2366<br>1159<br>1391<br>2289<br>1130<br>1398<br>1131M<br>861<br>882 | 2702<br>1681<br>115<br>685<br>763<br>2367<br>1161<br>1397<br>2306<br>1138<br>2012D<br>1140<br>863<br>886H | 2756<br>1682<br>219<br>1309<br>764<br>2368<br>1162<br>1398<br>2321D<br>1154<br>1154<br>864<br>887M | 2870<br>3080<br>224<br>1683<br>2369<br>2289D<br>2684<br>1157<br>1157<br>865M<br>889M | 3484<br>225-<br>2705<br>2370<br>2306<br>2867<br>1158M<br>1159<br>868<br>1831D | 232<br>2766<br>2371<br>1159<br>1258<br>870<br>1832H | 237<br>2782<br>2372<br>1163<br>2014D<br>872<br>1844M | 241<br>2375<br>1198M<br>873<br>1846M | 246<br>1258<br>874<br>3000D | | longtimeslic low lru lto l_cost l_scg_list l_seg_listc l_site l_size | 2525<br>68D<br>80D<br>251<br>754D<br>2360D<br>1089D<br>1387<br>1801<br>1100<br>1395m<br>1102<br>858D<br>878<br>3005 | 2655<br>112<br>114<br>271<br>756<br>2366<br>1159<br>1391<br>2289<br>1130<br>1398<br>1131M<br>861 | 2702<br>1681<br>115<br>685<br>763<br>2367<br>1161<br>1397<br>2306<br>1138<br>2012D<br>1140<br>863 | 2756<br>1682<br>219<br>1309<br>764<br>2368<br>1162<br>1398<br>2321D<br>1154 | 2870<br>3080<br>224<br>1683<br>2369<br>2289D<br>2684<br>1157<br>1157<br>865M | 3484<br>225-<br>2705<br>2370<br>2306<br>2867<br>1158H<br>1159<br>868 | 232<br>2766<br>2371<br>1159<br>1258<br>870 | 237<br>2782<br>2372<br>1163<br>2014D<br>872 | 241<br>2375<br>1198M<br>873 | 246<br>1258<br>874 | | longtimeslic low lru lto l_cost l_scg_list l_seg_listc l_site l_size m | 2525<br>68D<br>80D<br>251<br>754D<br>2360D<br>1089D<br>1387<br>1801<br>1100<br>1395m<br>1102<br>858D<br>878<br>3005<br>3203 | 2655<br>112<br>114<br>271<br>756<br>2366<br>1159<br>1391<br>2289<br>1130<br>1398<br>1131M<br>861<br>882 | 2702<br>1681<br>115<br>685<br>763<br>2367<br>1161<br>1397<br>2306<br>1138<br>2012D<br>1140<br>863<br>886H | 2756<br>1682<br>219<br>1309<br>764<br>2368<br>1162<br>1398<br>2321D<br>1154<br>1154<br>864<br>887M | 2870<br>3080<br>224<br>1683<br>2369<br>2289D<br>2684<br>1157<br>1157<br>865M<br>889M | 3484<br>225-<br>2705<br>2370<br>2306<br>2867<br>1158M<br>1159<br>868<br>1831D | 232<br>2766<br>2371<br>1159<br>1258<br>870<br>1832H | 237<br>2782<br>2372<br>1163<br>2014D<br>872<br>1844M | 241<br>2375<br>1198M<br>873<br>1846M | 246<br>1258<br>874<br>3000D | | longtimeslic low lru lto l_cost l_scg_list l_seg_listc l_site l_size m | 2525<br>68D<br>80D<br>251<br>754D<br>2360D<br>1089D<br>1387<br>1801<br>1100<br>1395m<br>1102<br>858D<br>878<br>3005<br>3203<br>199 | 2655<br>112<br>114<br>271<br>756<br>2366<br>1159<br>1391<br>2289<br>1130<br>1398<br>1131M<br>861<br>882<br>3007 | 2702<br>1681<br>115<br>685<br>763<br>2367<br>1161<br>1397<br>2306<br>1138<br>2012D<br>1140<br>863<br>886H | 2756<br>1682<br>219<br>1309<br>764<br>2368<br>1162<br>1398<br>2321D<br>1154<br>1154<br>864<br>887M | 2870<br>3080<br>224<br>1683<br>2369<br>2289D<br>2684<br>1157<br>1157<br>865M<br>889M | 3484<br>225-<br>2705<br>2370<br>2306<br>2867<br>1158M<br>1159<br>868<br>1831D | 232<br>2766<br>2371<br>1159<br>1258<br>870<br>1832H | 237<br>2782<br>2372<br>1163<br>2014D<br>872<br>1844M | 241<br>2375<br>1198M<br>873<br>1846M | 246<br>1258<br>874<br>3000D | | longtimeslic low lru lto l_cost l_seg_list l_seg_listc l_site l_size m main make_disk_re | 2525<br>68D<br>80D<br>251<br>754D<br>2360D<br>1089D<br>1387<br>1801<br>1100<br>1395m<br>1102<br>858D<br>878<br>3005<br>3203<br>199<br>2346D | 2655<br>112<br>114<br>271<br>756<br>2366<br>1159<br>1391<br>2289<br>1130<br>1398<br>1131M<br>861<br>882<br>3007 | 2702<br>1681<br>115<br>685<br>763<br>2367<br>1161<br>1397<br>2306<br>1138<br>2012D<br>1140<br>863<br>886M<br>3013 | 2756<br>1682<br>219<br>1309<br>764<br>2368<br>1162<br>1398<br>2321D<br>1154<br>1154<br>864<br>887M | 2870<br>3080<br>224<br>1683<br>2369<br>2289D<br>2684<br>1157<br>1157<br>865M<br>889M | 3484<br>225-<br>2705<br>2370<br>2306<br>2867<br>1158M<br>1159<br>868<br>1831D | 232<br>2766<br>2371<br>1159<br>1258<br>870<br>1832H | 237<br>2782<br>2372<br>1163<br>2014D<br>872<br>1844M | 241<br>2375<br>1198M<br>873<br>1846M | 246<br>1258<br>874<br>3000D | | longtimeslic low lru lto l_cost l_seg_list l_seg_listc l_site l_size m main make_disk_re make_space | 2525<br>68D<br>80D<br>251<br>754D<br>2360D<br>1089D<br>1387<br>1801<br>1100<br>1395m<br>1102<br>858D<br>878<br>3005<br>3203<br>199<br>2346D<br>656 | 2655<br>112<br>114<br>271<br>756<br>2366<br>1159<br>1391<br>2289<br>1130<br>1398<br>1131M<br>861<br>882<br>3007 | 2702<br>1681<br>115<br>685<br>763<br>2367<br>1161<br>1397<br>2306<br>1138<br>2012D<br>1140<br>863<br>886M<br>3013 | 2756<br>1682<br>219<br>1309<br>764<br>2368<br>1162<br>1398<br>2321D<br>1154<br>1154<br>864<br>887M<br>3014 | 2870<br>3080<br>224<br>1683<br>2369<br>2289D<br>2684<br>1157<br>1157<br>865M<br>889M | 3484<br>225-<br>2705<br>2370<br>2306<br>2867<br>1158M<br>1159<br>868<br>1831D | 232<br>2766<br>2371<br>1159<br>1258<br>870<br>1832H | 237<br>2782<br>2372<br>1163<br>2014D<br>872<br>1844M | 241<br>2375<br>1198M<br>873<br>1846M | 246<br>1258<br>874<br>3000D | | longtimeslic low lru lto l_cost l_scg_list l_seg_listc l_site l_size m main make_disk_re make_space make_workspa | 2525<br>68D<br>80D<br>251<br>754D<br>2360D<br>1089D<br>1387<br>1801<br>1100<br>1395m<br>1102<br>858D<br>878<br>3005<br>3203<br>199<br>2346D<br>656<br>2337D | 2655<br>112<br>114<br>271<br>756<br>2366<br>1159<br>1391<br>2289<br>1130<br>1398<br>1131M<br>861<br>882<br>3007 | 2702<br>1681<br>115<br>685<br>763<br>2367<br>1161<br>1397<br>2306<br>1138<br>2012D<br>1140<br>863<br>886H<br>3013 | 2756<br>1682<br>219<br>1309<br>764<br>2368<br>1162<br>1398<br>2321D<br>1154<br>1154<br>864<br>887M<br>3014 | 2870<br>3080<br>224<br>1683<br>2369<br>2289D<br>2684<br>1157<br>1157<br>865M<br>889M<br>3015 | 3484<br>225-<br>2705<br>2370<br>2306<br>2867<br>1158H<br>1159<br>868<br>1831D<br>3017H | 232<br>2766<br>2371<br>1159<br>1258<br>870<br>1832H | 237<br>2782<br>2372<br>1163<br>2014D<br>872<br>1844M | 241<br>2375<br>1198M<br>873<br>1846M | 246<br>1258<br>874<br>3000D | | longtimeslic low lru lto l_cost l_seg_list l_seg_listc l_site l_size m main make_disk_re make_space make_workspa maskf | 2525<br>68D<br>80D<br>251<br>754D<br>2360D<br>1089D<br>1387<br>1801<br>1100<br>1395m<br>1102<br>858D<br>878<br>3005<br>3203<br>199<br>2346D<br>656<br>2337D<br>584D | 2655<br>112<br>114<br>271<br>756<br>2366<br>1159<br>1391<br>2289<br>1130<br>1398<br>1131M<br>861<br>882<br>3007 | 2702<br>1681<br>115<br>685<br>763<br>2367<br>1161<br>1397<br>2306<br>1138<br>2012D<br>1140<br>863<br>886M<br>3013 | 2756<br>1682<br>219<br>1309<br>764<br>2368<br>1162<br>1398<br>2321D<br>1154<br>1154<br>864<br>887M<br>3014 | 2870<br>3080<br>224<br>1683<br>2369<br>2289D<br>2684<br>1157<br>1157<br>865M<br>889M | 3484<br>225-<br>2705<br>2370<br>2306<br>2867<br>1158M<br>1159<br>868<br>1831D | 232<br>2766<br>2371<br>1159<br>1258<br>870<br>1832H | 237<br>2782<br>2372<br>1163<br>2014D<br>872<br>1844M | 241<br>2375<br>1198M<br>873<br>1846M | 246<br>1258<br>874<br>3000D | | longtimeslic low lru lto l_cost l_scg_list l_seg_listc l_site l_size m main make_disk_re make_workspa maskf master | 2525<br>68D<br>80D<br>251<br>754D<br>2360D<br>1089D<br>1387<br>1801<br>1100<br>1395m<br>1102<br>858D<br>878<br>3005<br>3203<br>199<br>2346D<br>656<br>2337D<br>584D<br>333D | 2655<br>112<br>114<br>271<br>756<br>2366<br>1159<br>1391<br>2289<br>1130<br>1398<br>1131M<br>861<br>882<br>3007 | 2702<br>1681<br>115<br>685<br>763<br>2367<br>1161<br>1397<br>2306<br>1138<br>2012D<br>1140<br>863<br>886H<br>3013 | 2756<br>1682<br>219<br>1309<br>764<br>2368<br>1162<br>1398<br>2321D<br>1154<br>1154<br>864<br>887M<br>3014 | 2870<br>3080<br>224<br>1683<br>2369<br>2289D<br>2684<br>1157<br>1157<br>865M<br>889M<br>3015 | 3484<br>225-<br>2705<br>2370<br>2306<br>2867<br>1158H<br>1159<br>868<br>1831D<br>3017H | 232<br>2766<br>2371<br>1159<br>1258<br>870<br>1832H | 237<br>2782<br>2372<br>1163<br>2014D<br>872<br>1844M | 241<br>2375<br>1198M<br>873<br>1846M | 246<br>1258<br>874<br>3000D | | longtimeslic low lru lto l_cost l_seg_list l_seg_listc l_site l_size m main make_disk_re make_space make_workspa maskf | 2525<br>68D<br>80D<br>251<br>754D<br>2360D<br>1089D<br>1387<br>1801<br>1100<br>1395m<br>1102<br>858D<br>878<br>3005<br>3203<br>199<br>2346D<br>656<br>2337D<br>584D | 2655<br>112<br>114<br>271<br>756<br>2366<br>1159<br>1391<br>2289<br>1130<br>1398<br>1131M<br>861<br>882<br>3007 | 2702<br>1681<br>115<br>685<br>763<br>2367<br>1161<br>1397<br>2306<br>1138<br>2012D<br>1140<br>863<br>886H<br>3013 | 2756<br>1682<br>219<br>1309<br>764<br>2368<br>1162<br>1398<br>2321D<br>1154<br>1154<br>864<br>887M<br>3014 | 2870<br>3080<br>224<br>1683<br>2369<br>2289D<br>2684<br>1157<br>1157<br>865M<br>889M<br>3015 | 3484<br>225-<br>2705<br>2370<br>2306<br>2867<br>1158H<br>1159<br>868<br>1831D<br>3017H | 232<br>2766<br>2371<br>1159<br>1258<br>870<br>1832H | 237<br>2782<br>2372<br>1163<br>2014D<br>872<br>1844M | 241<br>2375<br>1198M<br>873<br>1846M | 246<br>1258<br>874<br>3000D | | longtimeslic low lru lto l_cost l_scg_list l_seg_listc l_site l_size m main make_disk_re make_workspa maskf master matchq | 2525<br>68D<br>80D<br>251<br>754D<br>2360D<br>1089D<br>1387<br>1801<br>1100<br>1395m<br>1102<br>858D<br>878<br>3005<br>3203<br>199<br>2346D<br>656<br>2337D<br>584D<br>333D<br>3158D | 2655<br>112<br>114<br>271<br>756<br>2366<br>1159<br>1391<br>2289<br>1130<br>1398<br>1131M<br>861<br>882<br>3007 | 2702<br>1681<br>115<br>685<br>763<br>2367<br>1161<br>1397<br>2306<br>1138<br>2012D<br>1140<br>863<br>886H<br>3013 | 2756<br>1682<br>219<br>1309<br>764<br>2368<br>1162<br>1398<br>2321D<br>1154<br>1154<br>864<br>887M<br>3014 | 2870<br>3080<br>224<br>1683<br>2369<br>2289D<br>2684<br>1157<br>1157<br>865M<br>889M<br>3015 | 3484<br>225-<br>2705<br>2370<br>2306<br>2867<br>1158H<br>1159<br>868<br>1831D<br>3017H | 232<br>2766<br>2371<br>1159<br>1258<br>870<br>1832H | 237<br>2782<br>2372<br>1163<br>2014D<br>872<br>1844M | 241<br>2375<br>1198M<br>873<br>1846M | 246<br>1258<br>874<br>3000D | | longtimeslic low lru lto l_cost l_scg_list l_seg_listc l_site l_size m main make_disk_re make_space make_workspa maskf master matchq max | 2525<br>68D<br>80D<br>251<br>754D<br>2360D<br>1089D<br>1387<br>1801<br>1100<br>1395m<br>1102<br>858D<br>878<br>3005<br>3203<br>199<br>2346D<br>656<br>2337D<br>584D<br>333D<br>3158D | 2655<br>112<br>114<br>271<br>756<br>2366<br>1159<br>1391<br>2289<br>1130<br>1398<br>1131M<br>861<br>882<br>3007<br>2775<br>748D<br>2489<br>615<br>373M<br>3171<br>391M | 2702<br>1681<br>115<br>685<br>763<br>2367<br>1161<br>1397<br>2306<br>1138<br>2012D<br>1140<br>863<br>886M<br>3013 | 2756<br>1682<br>219<br>1309<br>764<br>2368<br>1162<br>1398<br>2321D<br>1154<br>1154<br>864<br>887M<br>3014 | 2870<br>3080<br>224<br>1683<br>2369<br>2289D<br>2684<br>1157<br>1157<br>865M<br>889M<br>3015 | 3484<br>225-<br>2705<br>2370<br>2306<br>2867<br>1158H<br>1159<br>868<br>1831D<br>3017H | 232<br>2766<br>2371<br>1159<br>1258<br>870<br>1832M<br>3019M | 237<br>2782<br>2372<br>1163<br>2014D<br>872<br>1844M<br>3165D | 241<br>2375<br>1198M<br>873<br>1846M<br>3167 | 246<br>1258<br>874<br>3000D<br>3190 | | longtimeslic low lru lto l_cost l_scg_list l_seg_listc l_site l_size m main make_disk_re make_space make_workspa maskf master matchq max | 2525<br>68D<br>80D<br>251<br>754D<br>2360D<br>1089D<br>1387<br>1801<br>1100<br>1395m<br>1102<br>858D<br>878<br>3005<br>3203<br>199<br>2346D<br>656<br>2337D<br>584D<br>333D<br>3158D<br>384D<br>53D | 2655<br>112<br>114<br>271<br>756<br>2366<br>1159<br>1391<br>2289<br>1130<br>1398<br>1131M<br>861<br>882<br>3007<br>2775<br>748D<br>2489<br>615<br>373M<br>3171<br>391M<br>121 | 2702<br>1681<br>115<br>685<br>763<br>2367<br>1161<br>1397<br>2306<br>1138<br>2012D<br>1140<br>863<br>886M<br>3013 | 2756<br>1682<br>219<br>1309<br>764<br>2368<br>1162<br>1398<br>2321D<br>1154<br>1154<br>864<br>887M<br>3014 | 2870<br>3080<br>224<br>1683<br>2369<br>2289D<br>2684<br>1157<br>1157<br>865M<br>889M<br>3015 | 3484<br>225-<br>2705<br>2370<br>2306<br>2867<br>1158H<br>1159<br>868<br>1831D<br>3017H | 232<br>2766<br>2371<br>1159<br>1258<br>870<br>1832M<br>3019M | 237<br>2782<br>2372<br>1163<br>2014D<br>872<br>1844M<br>3165D | 241<br>2375<br>1198M<br>873<br>1846M<br>3167 | 246<br>1258<br>874<br>3000D<br>3190 | | longtimeslic low lru lto l_cost l_seg_list l_seg_listc l_site l_size m main make_disk_re make_workspa maskf master matchq max max_consoles max_disks | 2525<br>68D<br>80D<br>251<br>754D<br>2360D<br>1089D<br>1387<br>1801<br>1100<br>1395m<br>1102<br>858D<br>878<br>3005<br>3203<br>199<br>2346D<br>656<br>2337D<br>584D<br>333D<br>3158D<br>384D<br>53D | 2655<br>112<br>114<br>271<br>756<br>2366<br>1159<br>1391<br>2289<br>1130<br>1398<br>1131M<br>861<br>882<br>3007<br>2775<br>748D<br>2489<br>615<br>373M<br>3171<br>391M<br>121<br>3103<br>131 | 2702<br>1681<br>115<br>685<br>763<br>2367<br>1161<br>1397<br>2306<br>1138<br>2012D<br>1140<br>863<br>886H<br>3013 | 2756<br>1682<br>219<br>1309<br>764<br>2368<br>1162<br>1398<br>2321D<br>1154<br>1154<br>864<br>887M<br>3014<br>2657<br>1536<br>3234<br>408<br>154<br>2388 | 2870<br>3080<br>224<br>1683<br>2369<br>2289D<br>2684<br>1157<br>1157<br>865M<br>889M<br>3015 | 3484<br>225-<br>2705<br>2370<br>2306<br>2867<br>1158H<br>1159<br>868<br>1831D<br>3017M | 232<br>2766<br>2371<br>1159<br>1258<br>870<br>1832M<br>3019M | 237<br>2782<br>2372<br>1163<br>2014D<br>872<br>1844M<br>3165D | 241<br>2375<br>1198M<br>873<br>1846M<br>3167 | 246<br>1258<br>874<br>3000D<br>3190 | | longtimeslic low lru lto l_cost l_seg_list l_seg_listc l_site l_size m main make_disk_re make_space make_workspa maskf master matchq max max_consoles max_disks max_disk_buf | 2525<br>68D<br>80D<br>251<br>754D<br>2360D<br>1089D<br>1387<br>1801<br>1100<br>1395m<br>1102<br>858D<br>878<br>3005<br>3203<br>199<br>2346D<br>656<br>2337D<br>584D<br>333D<br>3158D<br>384D<br>53D<br>384D<br>53D<br>3097<br>56D<br>3479<br>57D | 2655<br>112<br>114<br>271<br>756<br>2366<br>1159<br>1391<br>2289<br>1130<br>1398<br>1131M<br>861<br>882<br>3007<br>2775<br>748D<br>2489<br>615<br>373M<br>3171<br>391M<br>121<br>3103<br>131<br>3480<br>142 | 2702<br>1681<br>115<br>685<br>763<br>2367<br>1161<br>1397<br>2306<br>1138<br>2012D<br>1140<br>863<br>886H<br>3013<br><br>771<br>2526<br>1533<br>3225<br>398<br>127<br>3447<br>140 | 2756<br>1682<br>219<br>1309<br>764<br>2368<br>1162<br>1398<br>2321D<br>1154<br>1154<br>864<br>887M<br>3014<br>2657<br>1536<br>3234<br>408<br>154<br>2388 | 2870<br>3080<br>224<br>1683<br>2369<br>2289D<br>2684<br>1157<br>1157<br>865M<br>889M<br>3015 | 3484<br>225-<br>2705<br>2370<br>2306<br>2867<br>1158H<br>1159<br>868<br>1831D<br>3017H | 232<br>2766<br>2371<br>1159<br>1258<br>870<br>1832N<br>3019M | 237<br>2782<br>2372<br>1163<br>2014D<br>872<br>1844M<br>3165D | 241<br>2375<br>1198M<br>873<br>1846N<br>3167 | 246 1258 874 3000D 3190 | | longtimeslic low lru lto l_cost l_seg_list l_seg_listc l_site l_size m main make_disk_re make_space make_workspa maskf master matchq max max_consoles max_disks max_disk_buf max_local_se | 2525<br>68D<br>80D<br>251<br>754D<br>2360D<br>1089D<br>1387<br>1801<br>1100<br>1395m<br>1102<br>858D<br>878<br>3005<br>3203<br>199<br>2346D<br>656<br>2337D<br>584D<br>333D<br>3158D<br>384D<br>53D<br>3097<br>56D<br>3479<br>57D<br>75D | 2655<br>112<br>114<br>271<br>756<br>2366<br>1159<br>1391<br>2289<br>1130<br>1398<br>1131M<br>861<br>882<br>3007<br>2775<br>748D<br>2489<br>615<br>373M<br>3171<br>391M<br>121<br>3103<br>131<br>3480<br>142<br>122 | 2702<br>1681<br>115<br>685<br>763<br>2367<br>1161<br>1397<br>2306<br>1138<br>2012D<br>1140<br>863<br>886M<br>3013<br><br>771<br>2526<br>1533<br>3225<br>398<br>127<br>3447<br>140 | 2756 1682 219 1309 764 2368 1162 1398 2321D 1154 1154 864 887M 3014 2657 1536 3234 408 154 2388 3237 | 2870<br>3080<br>224<br>1683<br>2369<br>2289D<br>2684<br>1157<br>1157<br>865M<br>889M<br>3015 | 3484<br>225-<br>2705<br>2370<br>2306<br>2867<br>1158H<br>1159<br>868<br>1831D<br>3017M | 232<br>2766<br>2371<br>1159<br>1258<br>870<br>1832M<br>3019M<br>2209<br>3141 | 237<br>2782<br>2372<br>1163<br>2014D<br>872<br>1844M<br>3165D<br>2399<br>3431 | 241 2375 1198M 873 1846M 3167 2517 3432 2083 | 246 1258 874 3000D 3190 2981 3476 | | longtimeslic low lru lto l_cost l_seg_list l_seg_listc l_site l_size m main make_disk_re make_space make_workspa maskf master matchq max max_consoles max_disks max_disk_buf max_local_se max_param_se | 2525<br>68D<br>80D<br>251<br>754D<br>2360D<br>1089D<br>1387<br>1801<br>1100<br>1395m<br>1102<br>858D<br>878<br>3005<br>3203<br>199<br>2346D<br>656<br>2337D<br>584D<br>333D<br>3158D<br>384D<br>53D<br>3097<br>56D<br>3479<br>57D<br>75D<br>77D | 2655<br>112<br>114<br>271<br>756<br>2366<br>1159<br>1391<br>2289<br>1130<br>1398<br>1131M<br>861<br>882<br>3007<br>2775<br>748D<br>2489<br>615<br>373M<br>3171<br>391M<br>121<br>3103<br>131<br>3480<br>142<br>122<br>123 | 2702<br>1681<br>115<br>685<br>763<br>2367<br>1161<br>1397<br>2306<br>1138<br>2012D<br>1140<br>863<br>886M<br>3013<br><br>771<br>2526<br>1533<br>3225<br>398<br>127<br>3447<br>140 | 2756 1682 219 1309 764 2368 1162 1398 2321D 1154 1154 864 887M 3014 2657 1536 3234 408 154 2388 3237 1382 1356 | 2870<br>3080<br>224<br>1683<br>2369<br>2289D<br>2684<br>1157<br>1157<br>865M<br>889M<br>3015<br>1575<br>158<br>2389<br>3477<br>1806<br>1368 | 3484<br>225-<br>2705<br>2370<br>2306<br>2867<br>1158H<br>1159<br>868<br>1831D<br>3017M<br>1587 | 232<br>2766<br>2371<br>1159<br>1258<br>870<br>1832N<br>3019M | 237<br>2782<br>2372<br>1163<br>2014D<br>872<br>1844M<br>3165D | 241<br>2375<br>1198M<br>873<br>1846N<br>3167 | 246 1258 874 3000D 3190 | | longtimeslic low lru lto l_cost l_scg_list l_seg_listc l_site l_size m main make_disk_re make_space make_workspa maskf master matchq max max_consoles max_disk_buf max_local_se max_param_se max_shifts | 2525<br>68D<br>80D<br>251<br>754D<br>2360D<br>1089D<br>1387<br>1801<br>1100<br>1395m<br>1102<br>858B<br>878<br>3005<br>3203<br>199<br>2346D<br>656<br>2337D<br>584D<br>333D<br>3158D<br>384D<br>53D<br>3097<br>56D<br>3479<br>57D<br>75D<br>77D<br>91D | 2655<br>112<br>114<br>271<br>756<br>2366<br>1159<br>1391<br>2289<br>1130<br>1398<br>1131M<br>861<br>882<br>3007<br>2775<br>748D<br>2489<br>615<br>373M<br>3171<br>391M<br>121<br>3103<br>131<br>3480<br>142<br>122<br>123<br>150 | 2702<br>1681<br>115<br>685<br>763<br>2367<br>1161<br>1397<br>2306<br>1138<br>2012D<br>1140<br>863<br>886H<br>3013<br><br>771<br>2526<br>1533<br>3225<br>398<br>127<br>3447<br>140 | 2756 1682 219 1309 764 2368 1162 1398 2321D 1154 1154 864 887M 3014 2657 1536 3234 408 154 2388 3237 | 2870<br>3080<br>224<br>1683<br>2369<br>2289D<br>2684<br>1157<br>1157<br>865M<br>889M<br>3015 | 3484<br>225-<br>2705<br>2370<br>2306<br>2867<br>1158H<br>1159<br>868<br>1831D<br>3017M | 232<br>2766<br>2371<br>1159<br>1258<br>870<br>1832M<br>3019M<br>2209<br>3141 | 237<br>2782<br>2372<br>1163<br>2014D<br>872<br>1844M<br>3165D<br>2399<br>3431 | 241 2375 1198M 873 1846M 3167 2517 3432 2083 | 246 1258 874 3000D 3190 2981 3476 | | longtimeslic low lru lto l_cost l_seg_list l_seg_listc l_site l_size m main make_disk_re make_workspa maskf master matchq max max_consoles max_disks max_disk_buf max_local_se max_shifts max_writes p | 2525<br>68D<br>80D<br>251<br>754D<br>2360D<br>1089D<br>1387<br>1801<br>1100<br>1395m<br>1102<br>858D<br>878<br>3005<br>3203<br>199<br>2346D<br>656<br>2337D<br>584D<br>333D<br>3158D<br>384D<br>53D<br>3097<br>56D<br>3479<br>57D<br>75D<br>77D<br>91D<br>59D | 2655<br>112<br>114<br>271<br>756<br>2366<br>1159<br>1391<br>2289<br>1130<br>1398<br>1131M<br>861<br>882<br>3007<br>2775<br>748D<br>2489<br>615<br>373M<br>3171<br>391M<br>121<br>3103<br>131<br>3480<br>142<br>122<br>123<br>150<br>143 | 2702<br>1681<br>115<br>685<br>763<br>2367<br>1161<br>1397<br>2306<br>1138<br>2012D<br>1140<br>863<br>886H<br>3013<br><br>771<br>2526<br>1533<br>3225<br>398<br>127<br>3447<br>140<br>143<br>1128<br>1115<br>1236<br>2869 | 2756 1682 219 1309 764 2368 1162 1398 2321D 1154 1154 864 887M 3014 2657 1536 3234 408 154 2388 3237 1382 1356 1267 | 2870<br>3080<br>224<br>1683<br>2369<br>2289D<br>2684<br>1157<br>1157<br>865M<br>889M<br>3015 | 3484<br>225-<br>2705<br>2370<br>2306<br>2867<br>1158H<br>1159<br>868<br>1831D<br>3017H<br>1587<br>160<br>2884 | 232<br>2766<br>2371<br>1159<br>1258<br>870<br>1832N<br>3019M<br>2209<br>3141<br>2034<br>2100 | 237<br>2782<br>2372<br>1163<br>2014D<br>872<br>1844M<br>3165D<br>2399<br>3431 | 241 2375 1198M 873 1846M 3167 2517 3432 2083 | 246 1258 874 3000D 3190 2981 3476 | | longtimeslic low lru lto l_cost l_scg_list l_seg_listc l_site l_size m main make_disk_re make_space make_workspa maskf master matchq max max_consoles max_disk_buf max_local_se max_param_se max_shifts | 2525<br>68D<br>80D<br>251<br>754D<br>2360D<br>1089D<br>1387<br>1801<br>1100<br>1395m<br>1102<br>858B<br>878<br>3005<br>3203<br>199<br>2346D<br>656<br>2337D<br>584D<br>333D<br>3158D<br>384D<br>53D<br>3097<br>56D<br>3479<br>57D<br>75D<br>77D<br>91D | 2655<br>112<br>114<br>271<br>756<br>2366<br>1159<br>1391<br>2289<br>1130<br>1398<br>1131M<br>861<br>882<br>3007<br>2775<br>748D<br>2489<br>615<br>373M<br>3171<br>391M<br>121<br>3103<br>131<br>3480<br>142<br>122<br>123<br>150 | 2702<br>1681<br>115<br>685<br>763<br>2367<br>1161<br>1397<br>2306<br>1138<br>2012D<br>1140<br>863<br>886H<br>3013<br><br>771<br>2526<br>1533<br>3225<br>398<br>127<br>3447<br>140 | 2756 1682 219 1309 764 2368 1162 1398 2321D 1154 1154 864 887M 3014 2657 1536 3234 408 154 2388 3237 1382 1356 | 2870<br>3080<br>224<br>1683<br>2369<br>2289D<br>2684<br>1157<br>1157<br>865M<br>889M<br>3015<br>1575<br>158<br>2389<br>3477<br>1806<br>1368 | 3484<br>225-<br>2705<br>2370<br>2306<br>2867<br>1158H<br>1159<br>868<br>1831D<br>3017M<br>1587 | 232<br>2766<br>2371<br>1159<br>1258<br>870<br>1832M<br>3019M<br>2209<br>3141 | 237<br>2782<br>2372<br>1163<br>2014D<br>872<br>1844M<br>3165D<br>2399<br>3431 | 241 2375 1198M 873 1846M 3167 2517 3432 2083 | 246 1258 874 3000D 3190 2981 3476 | | | 4 - 5 - | | | | 7.00 | | | | | | |---------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------| | memory_use | 605D<br>73D | 622<br>169 | 626<br>668 | 665<br>709 | 708 | | | | | | | mem_trace<br>mesdelay | 69D | 109 | 3007 | 3250 | 3486 | | | | | | | message | 3002D | 3005 | 3161D | . 3247 | 3248 | 3249 | 3250 | 3251 | 3252 | 3253M | | mfree | 591D | 623 | 626 | 627 | 652 | 656 | 659 | 661M | 663 | 665 | | | 669 | 687 | 688 | 689 | 706M | 70,7 | 708 | 710 | 733 | 735 | | | 736 | | | • | | | | | | | | migrations | 566D | 1228 | 3341 | 2206 | | | | | | | | mntrl | 61D | 137 | 138 | 2396 | 2206 | 2450 | 2517 | 2908 | • | | | mntru<br>mod | 61D<br>787 | 138<br>799 | 139<br>815 | 140<br>2393 | 2396<br>2395 | 2450<br>2397 | 2884 | 2900 | | | | monitor | 80D | 114 | 117 | 874 | 1426 | 2194 | 2716 | | | | | monitore | 1106 | 1423 | 1465 | 1500 | 1680 | 21610 | 2172 | 2493 | | | | more | 704D | 716 | 717 | 720 | 721 | | | | • | | | move | 2360D | 2476 | 2611 | 2701 | 2756 | | | | | | | msize | 49D | 125 | 623 | 626 | 665 | 669 | 708 | 710 | 1078 | 3424 | | mu. a | 3464<br>2176D | 2182 | 2192 | 2220 | 2707 · | 2709 | 2712 | 2846 | 2855 | | | my_q<br>m max | 625 | 956D | 963 | 965N | 969M | 975 | 978M | 982 | 1007 | | | m min | 625 | . 956D | 963 | 966M | 970M | 975 | 979M | 982 | -55. | | | m use | 627 | 931 | 952D | 965 | 966 | 969 | 970 | 972 | 978M | 979M | | <b>-</b> | 982m | 1007 | 1015 | 1018 | 107811 | 3417 | | | | | | n | 46D | 108 | 127M | 131 | 143 | 150 | 151 | 440D | 446M | 453 | | | 464<br>606 | 468<br>627 | 469<br>632 | 471<br>886 | 473M<br>922 | 475<br>952 | 476<br>961 | 477<br>976 | 485M<br>1012 | 559<br>1735 | | | 1739 | 1762 | 1952 | 2389M | 2393 | 2395 | 2397 . | 3015 | 3141M | 3330 | | | 3372 | 3416 | 3432 | 3446M | 3480 | 3510 | | 0015 | 22 (21) | 2330 | | negexp | 2425 | 2509 | 2620 | 3044 | | | | | | | | newsize | 2337D | 2343 | 2346D | 2352 | | | | | | | | new_did | 1856D | 1861 | 1867 | 1871 | 1880 | 1881 | 2072D | 2076 | 2446D | 2450 | | -au incomest | 2453<br>565D | 2456<br>2108 | 2903D<br>3337 | 2905 | 2909 | 2911 | | | | | | new_incarnat<br>new_site | 1740 | 1798 | 1973D | | | | | | | | | next inc | 2672D | 2700 | 2701 | 2705 | 2709 | 2711 | 2712 | 2715 | 2716 | 2779 | | <del>_</del> | 2782 | 2787 | | | | | | | | | | next_site | 1172 | 1173 | 1195 | 1199 | 1459 | 1460 | 1463 | 1687 | 1721 | 1723 | | | 1731 | 1941d | 1959 | | 2424 | 2425 | 0407 | 0.450 | | | | next_step | 1595M | 1597 | 2004D | 2032<br>2605 | 2424<br>2614 | 2435<br>2744 | 2437<br>2769 | 2458<br>2874 | 2477<br>2897 | 2508<br>2931 | | | 2544<br>2940 | 2562<br>2984 | 2575 | 2005 | 2014 | 2/44 | 2709 | 2074 | 2097 | 2931 | | | | | 22004 | 2202 | 222214 | 2201 | 2395M | 2396 | 2397M | 2399 | | nn | 2382D | 2388 | 730311 | 2392 | 2393N | .2394 | 239311 | 2370 | 237/11 | 4377 | | nn | 2382D<br>2401m | 2388<br>2402 | 2389M | 2392 | 2393M | 2394 | 239311 | 2390 | . 239711 | 2377 | | nn<br>non trivial | | | 3350 | 2392 | | .2394 | 2393N | 2390 | , 239/H | 2399 | | non_trivial<br>null | 2401m<br>570D<br>82D | 2402<br>3085<br>839 | | 2392 | 2393M<br>2378 | .2394 | 239311 | 2390 | , 2397H | 2399 | | non trivial<br>null<br>number | 2401m<br>570D<br>82D<br>327D | 2402<br>3085<br>839<br>329 | 3350<br>2035 | 2087 | 2378 | | 2393FI | 2370 | . 239711 | 2377 | | non_trivial<br>null<br>number<br>ondisk | 2401m<br>570D<br>82D<br>327D<br>. 82D | 2402<br>3085<br>839 | 3350 | | | -2394 | 239311 | 2370 | , 239/M | 2377 | | non_trivial<br>null<br>number<br>ondisk<br>open | 2401m<br>570D<br>82D<br>327D<br>. 82D<br>173 | 2402<br>3085<br>839<br>329<br>119 | 3350<br>2035<br>1118 | 2087<br>1372 | 2378<br>2351 | | 23936 | 2370 | . 239711 | 2399 | | non_trivial null number ondisk open optimum_site | 2401m<br>570D<br>82D<br>327D<br>. 82D | 2402<br>3085<br>839<br>329 | 3350<br>2035 | 2087 | 2378 | 1269 | 2393ft<br>1271M | 1316 | 1319h | 2377 | | non_trivial<br>null<br>number<br>ondisk<br>open | 2401m<br>570D<br>82D<br>327D<br>82D<br>173<br>998D<br>1220D<br>534D | 2402<br>3085<br>839<br>329<br>119<br>1021<br>1224<br>886M | 3350<br>2035<br>1118<br>1240<br>1225<br>887 | 2087<br>1372<br>1269<br>1239<br>889 | 2378<br>2351<br>1317<br>1241<br>903 | 1269<br>911 | 1271M<br>2994D | 1316<br>3021 | 1319N<br>3249 | | | non_trivial null number ondisk open optimum_site opt_site | 2401m<br>570D<br>82D<br>327D<br>82D<br>173<br>998D<br>1220D<br>534D<br>937 | 2402<br>3085<br>839<br>329<br>119<br>1021<br>1224<br>886M<br>1273 | 3350<br>2035<br>1118<br>1240<br>1225<br>887<br>1440 | 2087<br>1372<br>1269<br>1239 | 2378<br>2351<br>1317<br>1241 | 1269 | 1271M | 1316 | 13191 | 2198 | | non_trivial null number ondisk open optimum_site opt_site orgn out | 2401m<br>570D<br>82D<br>327D<br>82D<br>173<br>998D<br>1220D<br>534D<br>937 | 2402<br>3085<br>839<br>329<br>119<br>1021<br>1224<br>886M<br>1273<br>2696 | 3350<br>2035<br>1118<br>1240<br>1225<br>887<br>1440<br>3246 | 2087<br>1372<br>1269<br>1239<br>889<br>1443 | 2378<br>2351<br>1317<br>1241<br>903<br>1672 | 1269<br>911<br>1685 | 1271M<br>2994D<br>1787 | 1316<br>3021<br>1983 | 1319N<br>3249<br>2117 | 2198 | | non_trivial null number ondisk open optimum_site opt_site orgn | 2401m<br>570D<br>82D<br>327D<br>82D<br>173<br>998D<br>1220D<br>534D<br>937<br>2211<br>670 | 2402<br>3085<br>839<br>329<br>119<br>1021<br>1224<br>886M<br>1273<br>2696<br>711 | 3350<br>2035<br>1118<br>1240<br>1225<br>887<br>1440<br>3246<br>1628 | 2087<br>1372<br>1269<br>1239<br>889<br>1443<br>3135 | 2378<br>2351<br>1317<br>1241<br>903<br>1672<br>3389 | 1269<br>911<br>1685<br>3396 | 1271M<br>2994D<br>1787<br>3407 | 1316<br>3021 | 1319N<br>3249 | | | non_trivial null number ondisk open optimum_site opt_site orgn out | 2401m<br>570D<br>82D<br>327D<br>82D<br>173<br>998D<br>1220D<br>534D<br>937<br>2211<br>670<br>3455 | 2402<br>3085<br>839<br>329<br>119<br>1021<br>1224<br>886M<br>1273<br>2696<br>711<br>3462 | 3350<br>2035<br>1118<br>1240<br>1225<br>887<br>1440<br>3246<br>1628<br>3468 | 2087<br>1372<br>1269<br>1239<br>889<br>1443<br>3135<br>3474 | 2378<br>2351<br>1317<br>1241<br>903<br>1672<br>3389<br>3481 | 1269<br>911<br>1685<br>3396<br>3488 | 1271M<br>2994D<br>1787<br>3407<br>3490 | 1316<br>3021<br>1983<br>3418 | 1319N<br>3249<br>2117<br>3450 | 2198<br>3451 | | non_trivial null number ondisk open optimum_site opt_site orgn out | 2401m<br>570D<br>82D<br>327D<br>82D<br>173<br>998D<br>1220D<br>534D<br>937<br>2211<br>670 | 2402<br>3085<br>839<br>329<br>119<br>1021<br>1224<br>886M<br>1273<br>2696<br>711<br>3462<br>371<br>3458 | 3350<br>2035<br>1118<br>1240<br>1225<br>887<br>1440<br>3246<br>1628<br>3468<br>405<br>3482 | 2087<br>1372<br>1269<br>1239<br>889<br>1443<br>3135 | 2378<br>2351<br>1317<br>1241<br>903<br>1672<br>3389 | 1269<br>911<br>1685<br>3396 | 1271M<br>2994D<br>1787<br>3407 | 1316<br>3021<br>1983 | 1319N<br>3249<br>2117 | 2198 | | non_trivial null number ondisk open optimum_site opt_site orgn out | 2401m<br>570D<br>82D<br>327D<br>82D<br>173<br>998D<br>1220D<br>534D<br>937<br>2211<br>670<br>3455<br>184<br>487<br>191 | 2402<br>3085<br>839<br>329<br>119<br>1021<br>1224<br>886M<br>1273<br>2696<br>711<br>3462<br>371<br>3458<br>195 | 3350<br>2035<br>1118<br>1240<br>1225<br>887<br>1440<br>3246<br>1628<br>3468<br>405<br>3482<br>265 | 2087<br>1372<br>1269<br>1239<br>889<br>1443<br>3135<br>3474<br>424<br>3484<br>269 | 2378 2351 1317 1241 903 1672 3389 3481 476 3486 273 | 1269<br>911<br>1685<br>3396<br>3488<br>477<br>3507<br>282 | 1271M<br>2994D<br>1787<br>3407<br>3490<br>479<br>3510<br>303 | 1316<br>3021<br>1983<br>3418<br>481<br>305 | 1319N<br>3249<br>2117<br>3450<br>482<br>425 | 2198<br>3451<br>485<br>460 | | non_trivial null number ondisk open optimum_site opt_site orgn out outchar | 2401m<br>570D<br>82D<br>327D<br>82D<br>173<br>998D<br>1220D<br>534D<br>937<br>2211<br>670<br>3455<br>184<br>487<br>191 | 2402<br>3085<br>839<br>329<br>119<br>1021<br>1224<br>886M<br>1273<br>2696<br>711<br>3462<br>371<br>3458<br>195<br>475 | 3350<br>2035<br>1118<br>1240<br>1225<br>887<br>1440<br>3246<br>1628<br>3468<br>405<br>3482<br>265<br>479 | 2087<br>1372<br>1269<br>1239<br>889<br>1443<br>3135<br>3474<br>424<br>3484<br>269<br>489 | 2378 2351 1317 1241 903 1672 3389 3481 476 3486 273 504 | 1269<br>911<br>1685<br>3396<br>3488<br>477<br>3507<br>282<br>694 | 1271M<br>2994D<br>1787<br>3407<br>3490<br>479<br>3510<br>303<br>729 | 1316<br>3021<br>1983<br>3418<br>481<br>305<br>1906 | 1319M<br>3249<br>2117<br>3450<br>482<br>425<br>2468 | 2198<br>3451<br>485<br>460<br>2741 | | non_trivial null number ondisk open optimum_site opt_site orgn out outchar | 2401m<br>570D<br>82D<br>327D<br>. 82D<br>173<br>998D<br>1220D<br>534D<br>937<br>. 2211<br>670<br>3455<br>184<br>487<br>191<br>463<br>2825 | 2402<br>3085<br>839<br>329<br>119<br>1021<br>1224<br>886M<br>1273<br>2696<br>711<br>3462<br>371<br>3458<br>195<br>475<br>3068 | 3350<br>2035<br>1118<br>1240<br>1225<br>887<br>1440<br>3246<br>1628<br>3468<br>405<br>3482<br>265<br>479<br>3090 | 2087<br>1372<br>1269<br>1239<br>889<br>1443<br>3135<br>3474<br>424<br>3484<br>269<br>489<br>3109 | 2378 2351 1317 1241 903 1672 3389 3481 476 3486 273 504 3378 | 1269<br>911<br>1685<br>3396<br>3488<br>477<br>3507<br>282<br>694<br>3410 | 1271M<br>2994D<br>1787<br>3407<br>3490<br>479<br>3510<br>303<br>729<br>3415 | 1316<br>3021<br>1883<br>3418<br>481<br>305<br>1906<br>3426 | 1319N<br>3249<br>2117<br>3450<br>482<br>425<br>2468<br>3428 | 2198<br>3451<br>485<br>460<br>2741<br>3437 | | non_trivial null number ondisk open optimum_site opt_site orgn out outchar | 2401m<br>570D<br>82D<br>327D<br>82D<br>173<br>998D<br>1220D<br>534D<br>937<br>2211<br>670<br>3455<br>184<br>487<br>191<br>463<br>2825<br>3448 | 2402<br>3085<br>839<br>329<br>119<br>1021<br>1224<br>886M<br>1273<br>2696<br>711<br>3462<br>371<br>3458<br>195<br>475 | 3350<br>2035<br>1118<br>1240<br>1225<br>887<br>1440<br>3246<br>1628<br>3468<br>405<br>3482<br>265<br>479 | 2087<br>1372<br>1269<br>1239<br>889<br>1443<br>3135<br>3474<br>424<br>3484<br>269<br>489 | 2378 2351 1317 1241 903 1672 3389 3481 476 3486 273 504 | 1269<br>911<br>1685<br>3396<br>3488<br>477<br>3507<br>282<br>694 | 1271M<br>2994D<br>1787<br>3407<br>3490<br>479<br>3510<br>303<br>729 | 1316<br>3021<br>1983<br>3418<br>481<br>305<br>1906 | 1319M<br>3249<br>2117<br>3450<br>482<br>425<br>2468 | 2198<br>3451<br>485<br>460<br>2741 | | non_trivial null number ondisk open optimum_site opt_site orgn out outchar outfix outimage | 2401m<br>570D<br>82D<br>327D<br>82D<br>173<br>998D<br>1220D<br>534D<br>937<br>2211<br>670<br>3455<br>184<br>487<br>191<br>463<br>2825<br>3448<br>3511 | 2402<br>3085<br>839<br>329<br>119<br>1021<br>1224<br>886M<br>1273<br>2696<br>711<br>3462<br>371<br>3458<br>195<br>475<br>3068<br>3450 | 3350<br>2035<br>1118<br>1240<br>1225<br>887<br>1440<br>3246<br>1628<br>3468<br>405<br>3482<br>265<br>479<br>3090<br>3455 | 2087<br>1372<br>1269<br>1239<br>889<br>1443<br>3135<br>3474<br>424<br>3484<br>269<br>489<br>3109<br>3462 | 2378 2351 1317 1241 903 1672 3389 3481 476 3486 273 504 3378 | 1269<br>911<br>1685<br>3396<br>3488<br>477<br>3507<br>282<br>694<br>3410<br>3474 | 1271M<br>2994D<br>1787<br>3407<br>3490<br>479<br>3510<br>303<br>729<br>3415 | 1316<br>3021<br>1983<br>3418<br>481<br>305<br>1906<br>3426<br>3489 | 1319N<br>3249<br>2117<br>3450<br>482<br>425<br>2468<br>3428 | 2198<br>3451<br>485<br>460<br>2741<br>3437<br>3508 | | non_trivial null number ondisk open optimum_site opt_site orgn out outchar | 2401m<br>570D<br>82D<br>327D<br>82D<br>173<br>998D<br>1220D<br>534D<br>937<br>2211<br>670<br>3455<br>184<br>487<br>191<br>463<br>2825<br>3448 | 2402<br>3085<br>839<br>329<br>119<br>1021<br>1224<br>886M<br>1273<br>2696<br>711<br>3462<br>371<br>3458<br>195<br>475<br>3068 | 3350<br>2035<br>1118<br>1240<br>1225<br>887<br>1440<br>3246<br>1628<br>3468<br>405<br>3482<br>265<br>479<br>3090 | 2087<br>1372<br>1269<br>1239<br>889<br>1443<br>3135<br>3474<br>424<br>3484<br>269<br>489<br>3109 | 2378 2351 1317 1241 903 1672 3389 3481 476 3486 273 504 3378 3468 | 1269<br>911<br>1685<br>3396<br>3488<br>477<br>3507<br>282<br>694<br>3410 | 1271M<br>2994D<br>1787<br>3407<br>3490<br>479<br>3510<br>303<br>729<br>3415<br>3481 | 1316<br>3021<br>1883<br>3418<br>481<br>305<br>1906<br>3426 | 1319M<br>3249<br>2117<br>3450<br>482<br>425<br>2468<br>3428<br>3490 | 2198<br>3451<br>485<br>460<br>2741<br>3437 | | non_trivial null number ondisk open optimum_site opt_site orgn out outchar outfix outimage | 2401m<br>570D<br>82D<br>327D<br>82D<br>173<br>998D<br>1220D<br>534D<br>937<br>2211<br>670<br>3455<br>184<br>487<br>191<br>463<br>2825<br>3448<br>3511<br>268<br>1903<br>3135 | 2402<br>3085<br>839<br>329<br>119<br>1021<br>1224<br>886M<br>1273<br>2696<br>711<br>3462<br>371<br>3458<br>195<br>475<br>3068<br>3450 | 3350<br>2035<br>1118<br>1240<br>1225<br>887<br>1440<br>3246<br>1628<br>3468<br>405<br>3482<br>265<br>479<br>3090<br>3455<br>408<br>2452<br>3393 | 2087<br>1372<br>1269<br>1239<br>889<br>1443<br>3135<br>3474<br>424<br>3484<br>269<br>489<br>3109<br>3462<br>475<br>2453<br>3404 | 2378 2351 1317 1241 903 1672 3389 3481 476 3486 273 504 3378 3468 669 2466 3412 | 1269<br>911<br>1685<br>3396<br>3488<br>477<br>3507<br>282<br>694<br>3410<br>3474<br>670<br>2468<br>3417 | 1271M<br>2994D<br>1787<br>3407<br>3490<br>479<br>3510<br>303<br>729<br>3415<br>3481<br>694<br>3069<br>3419 | 1316<br>3021<br>1883<br>3418<br>481<br>305<br>1906<br>3426<br>3489<br>710<br>3089<br>3424 | 1319N<br>3249<br>2117<br>3450<br>482<br>425<br>2468<br>3428<br>3490<br>711<br>3105<br>3425 | 2198<br>3451<br>485<br>460<br>2741<br>3437<br>3508<br>1628<br>3107<br>3436 | | non_trivial null number ondisk open optimum_site opt_site orgn out outchar outfix outimage | 2401m<br>570D<br>82D<br>327D<br>82D<br>173<br>998D<br>1220D<br>534D<br>937<br>2211<br>670<br>3455<br>184<br>487<br>191<br>463<br>2825<br>3448<br>3511<br>268<br>1903<br>3135<br>3446 | 2402<br>3085<br>839<br>329<br>119<br>1021<br>1224<br>886M<br>1273<br>2696<br>711<br>3462<br>371<br>3458<br>195<br>475<br>3068<br>3450 | 3350<br>2035<br>1118<br>1240<br>1225<br>887<br>1440<br>3246<br>1628<br>3468<br>405<br>3482<br>265<br>479<br>3090<br>3455<br>408<br>2452<br>3393<br>3460 | 2087<br>1372<br>1269<br>1239<br>889<br>1443<br>3135<br>3474<br>424<br>3484<br>269<br>489<br>3109<br>3462<br>475<br>2453<br>3404<br>3461 | 2378 2351 1317 1241 903 1672 3389 3481 476 3486 273 504 3378 3468 669 2466 3412 3464 | 1269<br>911<br>1685<br>3396<br>3488<br>477<br>3507<br>282<br>694<br>3410<br>3474<br>670<br>2468 | 1271M<br>2994D<br>1787<br>3407<br>3490<br>479<br>3510<br>303<br>729<br>3415<br>3481<br>694<br>3069 | 1316<br>3021<br>1983<br>3418<br>481<br>305<br>1906<br>3426<br>3489<br>710<br>3089 | 1319M<br>3249<br>2117<br>3450<br>482<br>425<br>2468<br>3428<br>3490<br>711<br>3105 | 2198<br>3451<br>485<br>460<br>2741<br>3437<br>3508<br>1628<br>3107 | | non_trivial null number ondisk open optimum_site opt_site orgn out outchar outfix outimage | 2401m<br>570D<br>82D<br>327D<br>82D<br>173<br>998D<br>1220D<br>534D<br>937<br>2211<br>670<br>3455<br>184<br>487<br>191<br>463<br>2825<br>3448<br>3511<br>268<br>1903<br>3135<br>3446<br>3475 | 2402<br>3085<br>839<br>329<br>119<br>1021<br>1224<br>886M<br>1273<br>2696<br>711<br>3462<br>371<br>3458<br>195<br>475<br>3068<br>3450 | 3350<br>2035<br>1118<br>1240<br>1225<br>887<br>1440<br>3246<br>1628<br>3468<br>405<br>3482<br>265<br>479<br>3090<br>3455<br>408<br>2452<br>3393 | 2087<br>1372<br>1269<br>1239<br>889<br>1443<br>3135<br>3474<br>424<br>3484<br>269<br>489<br>3109<br>3462<br>475<br>2453<br>3404 | 2378 2351 1317 1241 903 1672 3389 3481 476 3486 273 504 3378 3468 669 2466 3412 | 1269<br>911<br>1685<br>3396<br>3488<br>477<br>3507<br>282<br>694<br>3410<br>3474<br>670<br>2468<br>3417 | 1271M<br>2994D<br>1787<br>3407<br>3490<br>479<br>3510<br>303<br>729<br>3415<br>3481<br>694<br>3069<br>3419 | 1316<br>3021<br>1883<br>3418<br>481<br>305<br>1906<br>3426<br>3489<br>710<br>3089<br>3424 | 1319N<br>3249<br>2117<br>3450<br>482<br>425<br>2468<br>3428<br>3490<br>711<br>3105<br>3425 | 2198<br>3451<br>485<br>460<br>2741<br>3437<br>3508<br>1628<br>3107<br>3436 | | non_trivial null number ondisk open optimum_site opt_site orgn out outchar outfix outimage outint | 2401m<br>570D<br>82D<br>327D<br>82D<br>173<br>998D<br>1220D<br>534D<br>937<br>2211<br>670<br>3455<br>184<br>487<br>191<br>463<br>2825<br>3448<br>3511<br>268<br>1903<br>3135<br>3446<br>3475<br>4950 | 2402<br>3085<br>839<br>329<br>119<br>1021<br>1224<br>886M<br>1273<br>2696<br>711<br>3462<br>371<br>3458<br>195<br>475<br>3068<br>3450<br>320<br>1905<br>3385<br>3447<br>3476<br>3505 | 3350<br>2035<br>1118<br>1240<br>1225<br>887<br>1440<br>3246<br>1628<br>3468<br>405<br>3482<br>265<br>479<br>3090<br>3455<br>408<br>2452<br>3393<br>3460<br>3477 | 2087 1372 1269 1239 889 1443 3135 3474 424 3484 269 489 3109 3462 475 2453 3404 3461 3480 | 2378 2351 1317 1241 903 1672 3389 3481 476 3486 273 504 3378 3468 669 2466 3412 3464 3487 | 1269<br>911<br>1685<br>3396<br>3488<br>477<br>3507<br>282<br>694<br>3410<br>3474<br>670<br>2468<br>3417<br>3465 | 1271M<br>2994D<br>1787<br>3407<br>3490<br>479<br>3510<br>303<br>729<br>3415<br>3481<br>694<br>3069<br>3419<br>3466 | 1316<br>3021<br>1883<br>3418<br>481<br>305<br>1906<br>3426<br>3489<br>710<br>3089<br>3424<br>3467 | 1319M<br>3249<br>2117<br>3450<br>482<br>425<br>2468<br>3428<br>3490<br>711<br>3105<br>3425<br>3471 | 2198<br>3451<br>485<br>460<br>2741<br>3437<br>3508<br>1628<br>3107<br>3436<br>3473 | | non_trivial null number ondisk open optimum_site opt_site orgn out outchar outfix outimage | 2401m<br>570D<br>82D<br>327D<br>82D<br>173<br>998D<br>1220D<br>534D<br>937<br>2211<br>670<br>3455<br>184<br>487<br>191<br>463<br>2825<br>3448<br>3511<br>268<br>1903<br>3135<br>3446<br>3475 | 2402<br>3085<br>839<br>329<br>119<br>1021<br>1224<br>886M<br>1273<br>2696<br>711<br>3462<br>371<br>3458<br>195<br>475<br>3068<br>3450 | 3350<br>2035<br>1118<br>1240<br>1225<br>887<br>1440<br>3246<br>1628<br>3468<br>405<br>3482<br>265<br>479<br>3090<br>3455<br>408<br>2452<br>3393<br>3460 | 2087<br>1372<br>1269<br>1239<br>889<br>1443<br>3135<br>3474<br>424<br>3484<br>269<br>489<br>3109<br>3462<br>475<br>2453<br>3404<br>3461 | 2378 2351 1317 1241 903 1672 3389 3481 476 3486 273 504 3378 3468 669 2466 3412 3464 | 1269<br>911<br>1685<br>3396<br>3488<br>477<br>3507<br>282<br>694<br>3410<br>3474<br>670<br>2468<br>3417 | 1271M<br>2994D<br>1787<br>3407<br>3490<br>479<br>3510<br>303<br>729<br>3415<br>3481<br>694<br>3069<br>3419 | 1316<br>3021<br>1883<br>3418<br>481<br>305<br>1906<br>3426<br>3489<br>710<br>3089<br>3424 | 1319N<br>3249<br>2117<br>3450<br>482<br>425<br>2468<br>3428<br>3490<br>711<br>3105<br>3425 | 2198<br>3451<br>485<br>460<br>2741<br>3437<br>3508<br>1628<br>3107<br>3436 | | non_trivial null number ondisk open optimum_site opt_site orgn out outchar outfix outimage outint | 2401m<br>570D<br>82D<br>327D<br>82D<br>173<br>998D<br>1220D<br>534D<br>937<br>2211<br>670<br>3455<br>184<br>487<br>191<br>463<br>2825<br>3448<br>3511<br>268<br>1903<br>3135<br>3446<br>3475<br>495D<br>107 | 2402<br>3085<br>839<br>329<br>119<br>1021<br>1224<br>886M<br>1273<br>2696<br>711<br>3462<br>371<br>3458<br>195<br>475<br>3068<br>3450<br>320<br>1905<br>3385<br>3447<br>3476<br>3505<br>120 | 3350<br>2035<br>1118<br>1240<br>1225<br>887<br>1440<br>3246<br>1628<br>3468<br>405<br>3482<br>265<br>479<br>3090<br>3455<br>408<br>2452<br>3393<br>3460<br>3477 | 2087<br>1372<br>1269<br>1239<br>889<br>1443<br>3135<br>3474<br>424<br>3484<br>269<br>489<br>3109<br>3462<br>475<br>2453<br>3404<br>3461<br>3480 | 2378 2351 1317 1241 903 1672 3389 3481 476 3486 273 504 3378 3468 669 2466 3412 3464 3487 | 1269<br>911<br>1685<br>3396<br>3488<br>477<br>3507<br>282<br>694<br>3410<br>3474<br>670<br>2468<br>3417<br>3465 | 1271M<br>2994D<br>1787<br>3407<br>3490<br>479<br>3510<br>303<br>729<br>3415<br>3481<br>694<br>3069<br>3419<br>3466 | 1316<br>3021<br>1983<br>3418<br>481<br>305<br>1906<br>3426<br>3489<br>710<br>3089<br>3424<br>3467 | 1319M<br>3249<br>2117<br>3450<br>482<br>425<br>2468<br>3428<br>3490<br>711<br>3105<br>3425<br>3471 | 2198<br>3451<br>485<br>460<br>2741<br>3437<br>3508<br>1628<br>3107<br>3436<br>3473 | | non_trivial null number ondisk open optimum_site opt_site orgn out outchar outfix outimage outint | 2401m<br>570D<br>82D<br>327D<br>. 82D<br>173<br>998D<br>1220D<br>534D<br>937<br>. 2211<br>670<br>3455<br>184<br>487<br>191<br>463<br>2825<br>3448<br>3511<br>268<br>1903<br>3135<br>3446<br>3475<br>495D<br>107<br>318<br>475<br>728 | 2402<br>3085<br>839<br>329<br>119<br>1021<br>1224<br>886M<br>1273<br>2696<br>711<br>3462<br>371<br>3458<br>195<br>475<br>3068<br>3450<br>1905<br>3385<br>3447<br>3476<br>3505<br>120<br>319<br>476m<br>1628 | 3350<br>2035<br>1118<br>1240<br>1225<br>887<br>1440<br>3246<br>1628<br>3468<br>405<br>3482<br>265<br>479<br>3090<br>3455<br>408<br>2452<br>3393<br>3460<br>3477<br>184<br>369N<br>477M<br>1629 | 2087 1372 1269 1239 889 1443 3135 3474 424 3484 269 489 3109 3462 475 2453 3404 3461 3480 191 404M 478 1902 | 2378 2351 1317 1241 903 1672 3389 3481 476 3486 273 504 3378 3468 669 2466 3412 3464 3487 | 1269<br>911<br>1685<br>3396<br>3488<br>477<br>3507<br>282<br>694<br>3410<br>3474<br>670<br>2468<br>3417<br>3465 | 1271M<br>2994D<br>1787<br>3407<br>3490<br>479<br>3510<br>303<br>729<br>3415<br>3481<br>694<br>3069<br>3419<br>3466 | 1316<br>3021<br>1883<br>3418<br>481<br>305<br>1906<br>3426<br>3489<br>710<br>3089<br>3424<br>3467 | 1319N<br>3249<br>2117<br>3450<br>482<br>425<br>2468<br>3428<br>3490<br>711<br>3105<br>3425<br>3471<br>278<br>462M<br>488<br>2506 | 2198 3451 485 460 2741 3437 3508 1628 3107 3436 3473 . 304 463 693M 2542 | | non_trivial null number ondisk open optimum_site opt_site orgn out outchar outfix outimage outint | 2401m<br>570D<br>82D<br>327D<br>82D<br>173<br>998D<br>1220D<br>534D<br>937<br>2211<br>670<br>3455<br>184<br>487<br>191<br>463<br>2825<br>3448<br>3511<br>268<br>1903<br>3135<br>3446<br>3475<br>495D<br>107<br>318<br>475<br>728<br>2598 | 2402<br>3085<br>839<br>329<br>119<br>1021<br>1224<br>886M<br>1273<br>2696<br>711<br>3462<br>371<br>3458<br>195<br>475<br>3068<br>3450<br>1905<br>3385<br>3447<br>3476<br>3505<br>120<br>319<br>476m<br>1628<br>2739 | 3350<br>2035<br>1118<br>1240<br>1225<br>887<br>1440<br>3246<br>1628<br>3468<br>405<br>3482<br>265<br>479<br>3090<br>3455<br>408<br>2452<br>3393<br>3460<br>3477<br>184<br>369N<br>477M<br>1629<br>2825 | 2087 1372 1269 1239 889 1443 3135 3474 424 3484 269 489 3109 3462 475 2453 3404 3461 3480 191 404M 478 1902 3069 | 2378 2351 1317 1241 903 1672 3389 3481 476 3486 273 504 3378 3468 669 2466 3412 3464 3487 193 408 480 1904 3089 | 1269<br>911<br>1685<br>3396<br>3488<br>477<br>3507<br>282<br>694<br>3410<br>3474<br>670<br>2468<br>3417<br>3465 | 1271M<br>2994D<br>1787<br>3407<br>3490<br>479<br>3510<br>303<br>729<br>3415<br>3481<br>694<br>3069<br>3419<br>3466<br>267M<br>423<br>483<br>2452<br>3106 | 1316<br>3021<br>1883<br>3418<br>481<br>305<br>1906<br>3426<br>3489<br>710<br>3089<br>3424<br>3467<br>273<br>461<br>486<br>2467<br>3378 | 1319N<br>3249<br>2117<br>3450<br>482<br>425<br>2468<br>3428<br>3490<br>711<br>3105<br>3425<br>3471<br>278<br>462M<br>488<br>2506<br>3386M | 2198 3451 485 460 2741 3437 3508 1628 3107 3436 3473 . 304 463 693M 2542 3400 | | non_trivial null number ondisk open optimum_site opt_site orgn out outchar outfix outimage outint | 2401m<br>570D<br>82D<br>327D<br>82D<br>173<br>998D<br>1220D<br>534D<br>937<br>2211<br>670<br>3455<br>184<br>487<br>191<br>463<br>2825<br>3448<br>3511<br>268<br>1903<br>3135<br>3446<br>3475<br>495D<br>107<br>318<br>475<br>728<br>2598<br>3411 | 2402<br>3085<br>839<br>329<br>119<br>1021<br>1224<br>886M<br>1273<br>2696<br>711<br>3462<br>371<br>3458<br>195<br>475<br>3068<br>3450<br>320<br>1905<br>3385<br>3447<br>3476<br>3505<br>120<br>319<br>476m<br>1628<br>2739<br>3421 | 3350<br>2035<br>1118<br>1240<br>1225<br>887<br>1440<br>3246<br>1628<br>3468<br>405<br>3482<br>265<br>479<br>3090<br>3455<br>408<br>2452<br>3393<br>3460<br>3477<br>184<br>369N<br>477M<br>1629<br>2825<br>3425 | 2087 1372 1269 1239 889 1443 3135 3474 424 3484 269 489 3109 3462 475 2453 3404 3461 3480 191 404N 478 1902 3069 3429 | 2378 2351 1317 1241 903 1672 3389 3481 476 3486 273 504 3378 3468 669 2466 3412 3464 3487 193 408 480 1904 3089 3445 | 1269<br>911<br>1685<br>3396<br>3488<br>477<br>3507<br>282<br>694<br>3410<br>3474<br>670<br>2468<br>3417<br>3465 | 1271M<br>2994D<br>1787<br>3407<br>3490<br>479<br>3510<br>303<br>729<br>3415<br>3481<br>694<br>3069<br>3419<br>3466<br>267M<br>423<br>483<br>2452<br>3106<br>3447 | 1316<br>3021<br>1983<br>3418<br>481<br>305<br>1906<br>3426<br>3489<br>710<br>3089<br>3424<br>3467<br>273<br>461<br>486<br>2467<br>3378<br>3452 | 1319M<br>3249<br>2117<br>3450<br>482<br>425<br>2468<br>3428<br>3490<br>711<br>3105<br>3425<br>3471<br>278<br>462M<br>488<br>2506<br>3386M<br>3453 | 2198 3451 485 460 2741 3437 3508 1628 3107 3436 3473 . 304 463 693M 2542 3400 3454 | | non_trivial null number ondisk open optimum_site opt_site orgn out outchar outfix outimage outint | 2401m<br>570D<br>82D<br>327D<br>82D<br>173<br>998D<br>1220D<br>534D<br>937<br>2211<br>670<br>3455<br>184<br>487<br>191<br>463<br>2825<br>3448<br>3511<br>268<br>1903<br>3135<br>3446<br>3475<br>495D<br>107<br>318<br>475<br>728<br>2598<br>3411<br>3457 | 2402<br>3085<br>839<br>329<br>119<br>1021<br>1224<br>886M<br>1273<br>2696<br>711<br>3462<br>371<br>3458<br>195<br>475<br>3068<br>3450<br>320<br>1905<br>3385<br>3447<br>3476<br>3505<br>120<br>319<br>476m<br>1628<br>2739<br>3421<br>3459 | 3350<br>2035<br>1118<br>1240<br>1225<br>887<br>1440<br>3246<br>1628<br>3468<br>405<br>3482<br>265<br>479<br>3090<br>3455<br>408<br>2452<br>3393<br>3460<br>3477<br>184<br>369N<br>477M<br>1629<br>2825<br>3425<br>3425<br>3461 | 2087 1372 1269 1239 889 1443 3135 3474 424 3484 269 489 3109 3462 475 2453 3404 3461 3480 191 404M 478 1902 3069 3429 3464 | 2378 2351 1317 1241 903 1672 3389 3481 476 3486 273 504 3378 3468 669 2466 3412 3464 3487 193 408 480 1904 3089 3445 3465 | 1269<br>911<br>1685<br>3396<br>3488<br>477<br>3507<br>282<br>694<br>3410<br>3474<br>670<br>2468<br>3417<br>3465 | 1271M<br>2994D<br>1787<br>3407<br>3490<br>479<br>3510<br>303<br>729<br>3415<br>3481<br>694<br>3069<br>3419<br>3466<br>267M<br>423<br>483<br>2452<br>3106<br>3447<br>3467 | 1316<br>3021<br>1883<br>3418<br>481<br>305<br>1906<br>3426<br>3489<br>710<br>3089<br>3424<br>3467<br>273<br>461<br>486<br>2467<br>3378<br>3452<br>3469 | 1319M<br>3249<br>2117<br>3450<br>482<br>425<br>2468<br>3428<br>3490<br>711<br>3105<br>3425<br>3471<br>278<br>462M<br>488<br>2506<br>3386M<br>3453<br>3470 | 2198 3451 485 460 2741 3437 3508 1628 3107 3436 3473 304 463 693M 2542 3400 3454 3472 | | non_trivial null number ondisk open optimum_site opt_site orgn out outchar outfix outimage outint | 2401m<br>570D<br>82D<br>327D<br>82D<br>173<br>998D<br>1220D<br>534D<br>937<br>2211<br>670<br>3455<br>184<br>487<br>191<br>463<br>2825<br>3448<br>3511<br>268<br>1903<br>3135<br>3446<br>3475<br>495D<br>107<br>318<br>475<br>728<br>2598<br>3411<br>3457<br>3475 | 2402<br>3085<br>839<br>329<br>119<br>1021<br>1224<br>886M<br>1273<br>2696<br>711<br>3462<br>371<br>3458<br>195<br>475<br>3068<br>3450<br>320<br>1905<br>3385<br>3447<br>3476<br>3505<br>120<br>319<br>476m<br>1628<br>2739<br>3421<br>3459<br>3476 | 3350<br>2035<br>1118<br>1240<br>1225<br>887<br>1440<br>3246<br>1628<br>3468<br>405<br>3482<br>265<br>479<br>3090<br>3455<br>408<br>2452<br>3393<br>3460<br>3477<br>184<br>369N<br>477M<br>1629<br>2825<br>3425 | 2087 1372 1269 1239 889 1443 3135 3474 424 3484 269 489 3109 3462 475 2453 3404 3461 3480 191 404N 478 1902 3069 3429 | 2378 2351 1317 1241 903 1672 3389 3481 476 3486 273 504 3378 3468 669 2466 3412 3464 3487 193 408 480 1904 3089 3445 | 1269<br>911<br>1685<br>3396<br>3488<br>477<br>3507<br>282<br>694<br>3410<br>3474<br>670<br>2468<br>3417<br>3465 | 1271M<br>2994D<br>1787<br>3407<br>3490<br>479<br>3510<br>303<br>729<br>3415<br>3481<br>694<br>3069<br>3419<br>3466<br>267M<br>423<br>483<br>2452<br>3106<br>3447 | 1316<br>3021<br>1983<br>3418<br>481<br>305<br>1906<br>3426<br>3489<br>710<br>3089<br>3424<br>3467<br>273<br>461<br>486<br>2467<br>3378<br>3452 | 1319M<br>3249<br>2117<br>3450<br>482<br>425<br>2468<br>3428<br>3490<br>711<br>3105<br>3425<br>3471<br>278<br>462M<br>488<br>2506<br>3386M<br>3453 | 2198 3451 485 460 2741 3437 3508 1628 3107 3436 3473 . 304 463 693M 2542 3400 3454 | | non_trivial null number ondisk open optimum_site opt_site orgn out outchar outfix outimage outint | 2401m<br>570D<br>82D<br>327D<br>. 82D<br>173<br>998D<br>1220D<br>534D<br>937<br>. 2211<br>670<br>3455<br>184<br>487<br>191<br>463<br>2825<br>3448<br>3511<br>268<br>1903<br>3135<br>3446<br>3475<br>495D<br>107<br>318<br>475<br>728<br>2598<br>3411<br>3457<br>3475<br>3506<br>567D | 2402<br>3085<br>839<br>329<br>119<br>1021<br>1224<br>886M<br>1273<br>2696<br>711<br>3458<br>195<br>475<br>3068<br>3450<br>320<br>1905<br>3385<br>3447<br>3476<br>3505<br>120<br>319<br>476m<br>1628<br>2739<br>3421<br>3459<br>3421<br>3459<br>3421<br>3459<br>3421<br>3459<br>3083 | 3350<br>2035<br>1118<br>1240<br>1225<br>887<br>1440<br>3246<br>1628<br>3468<br>405<br>3482<br>265<br>479<br>3090<br>3455<br>408<br>2452<br>3393<br>3460<br>3477<br>184<br>369M<br>477M<br>1629<br>2825<br>3425<br>3461<br>3477 | 2087 1372 1269 1239 889 1443 3135 3474 424 3484 269 489 3109 3462 475 2453 3404 3461 3480 191 404M 478 1902 3069 3429 3464 | 2378 2351 1317 1241 903 1672 3389 3481 476 3486 273 504 3378 3468 669 2466 3412 3464 3487 193 408 480 1904 3089 3445 3465 | 1269<br>911<br>1685<br>3396<br>3488<br>477<br>3507<br>282<br>694<br>3410<br>3474<br>670<br>2468<br>3417<br>3465 | 1271M<br>2994D<br>1787<br>3407<br>3490<br>479<br>3510<br>303<br>729<br>3415<br>3481<br>694<br>3069<br>3419<br>3466<br>267M<br>423<br>483<br>2452<br>3106<br>3447<br>3467 | 1316<br>3021<br>1883<br>3418<br>481<br>305<br>1906<br>3426<br>3489<br>710<br>3089<br>3424<br>3467<br>273<br>461<br>486<br>2467<br>3378<br>3452<br>3469 | 1319M<br>3249<br>2117<br>3450<br>482<br>425<br>2468<br>3428<br>3490<br>711<br>3105<br>3425<br>3471<br>278<br>462M<br>488<br>2506<br>3386M<br>3453<br>3470 | 2198 3451 485 460 2741 3437 3508 1628 3107 3436 3473 . 304 463 693M 2542 3400 3454 3472 | | non_trivial null number ondisk open optimum_site opt_site orgn out outchar outfix outimage outint outputstatis outtext | 2401m<br>570D<br>82D<br>327D<br>82D<br>173<br>998D<br>1220D<br>534D<br>937<br>2211<br>670<br>3455<br>184<br>487<br>191<br>463<br>2825<br>3448<br>3511<br>268<br>1903<br>3135<br>3446<br>3475<br>495D<br>107<br>318<br>475<br>728<br>2598<br>3411<br>3457<br>3475<br>3506<br>567D<br>567D | 2402<br>3085<br>839<br>329<br>119<br>1021<br>1224<br>886M<br>1273<br>2696<br>711<br>3452<br>371<br>3458<br>195<br>475<br>3068<br>3450<br>320<br>1905<br>3385<br>3447<br>3476<br>3505<br>120<br>319<br>476m<br>1628<br>2739<br>3421<br>3459<br>3421<br>3459<br>3421<br>3459<br>3483<br>3684 | 3350<br>2035<br>1118<br>1240<br>1225<br>887<br>1440<br>3246<br>1628<br>3468<br>405<br>3482<br>265<br>479<br>3090<br>3455<br>408<br>2452<br>3393<br>3460<br>3477<br>184<br>369N<br>477M<br>1629<br>2825<br>3425<br>3461<br>3477 | 2087 1372 1269 1239 889 1443 3135 3474 424 3484 269 489 3109 3462 475 2453 3404 3461 3480 191 404N 478 1902 3069 3429 3464 3478 | 2378 2351 1317 1241 903 1672 3389 3481 476 3486 273 504 3378 3468 669 2466 3412 3464 3487 193 408 480 1904 3089 3445 3465 3482 | 1269<br>911<br>1685<br>3396<br>3488<br>477<br>3507<br>282<br>694<br>3410<br>3474<br>670<br>2468<br>3417<br>3465 | 1271M<br>2994D<br>1787<br>3407<br>3490<br>479<br>3510<br>303<br>729<br>3415<br>3481<br>694<br>3069<br>3419<br>3466<br>267M<br>423<br>483<br>2452<br>3106<br>3447<br>3467<br>3485 | 1316<br>3021<br>1983<br>3418<br>481<br>305<br>1906<br>3426<br>3489<br>710<br>3089<br>3424<br>3467<br>273<br>461<br>486<br>2467<br>3378<br>3452<br>3469<br>3487 | 1319M<br>3249<br>2117<br>3450<br>482<br>425<br>2468<br>3428<br>3490<br>711<br>3105<br>3425<br>3471<br>278<br>462M<br>488<br>2506<br>3386M<br>3453<br>3470<br>3499 | 2198 3451 485 460 2741 3437 3508 1628 3107 3436 3473 . 304 463 693M 2542 3400 3454 3472 3502 | | non_trivial null number ondisk open optimum_site opt_site orgn out outchar outfix outimage outint outputstatis (outtext | 2401m<br>570D<br>82D<br>327D<br>. 82D<br>173<br>998D<br>1220D<br>534D<br>937<br>. 2211<br>670<br>3455<br>184<br>487<br>191<br>463<br>2825<br>3448<br>3511<br>268<br>1903<br>3135<br>3446<br>3475<br>495D<br>107<br>318<br>475<br>728<br>2598<br>3411<br>3457<br>3475<br>3506<br>567D | 2402<br>3085<br>839<br>329<br>119<br>1021<br>1224<br>886M<br>1273<br>2696<br>711<br>3458<br>195<br>475<br>3068<br>3450<br>320<br>1905<br>3385<br>3447<br>3476<br>3505<br>120<br>319<br>476m<br>1628<br>2739<br>3421<br>3459<br>3421<br>3459<br>3421<br>3459<br>3421<br>3459<br>3083 | 3350<br>2035<br>1118<br>1240<br>1225<br>887<br>1440<br>3246<br>1628<br>3468<br>405<br>3482<br>265<br>479<br>3090<br>3455<br>408<br>2452<br>3393<br>3460<br>3477<br>184<br>369M<br>477M<br>1629<br>2825<br>3425<br>3461<br>3477 | 2087 1372 1269 1239 889 1443 3135 3474 424 3484 269 489 3109 3462 475 2453 3404 3461 3480 191 404M 478 1902 3069 3429 3464 | 2378 2351 1317 1241 903 1672 3389 3481 476 3486 273 504 3378 3468 669 2466 3412 3464 3487 193 408 480 1904 3089 3445 3465 | 1269<br>911<br>1685<br>3396<br>3488<br>477<br>3507<br>282<br>694<br>3410<br>3474<br>670<br>2468<br>3417<br>3465 | 1271M<br>2994D<br>1787<br>3407<br>3490<br>479<br>3510<br>303<br>729<br>3415<br>3481<br>694<br>3069<br>3419<br>3466<br>267M<br>423<br>483<br>2452<br>3106<br>3447<br>3467 | 1316<br>3021<br>1883<br>3418<br>481<br>305<br>1906<br>3426<br>3489<br>710<br>3089<br>3424<br>3467<br>273<br>461<br>486<br>2467<br>3378<br>3452<br>3469 | 1319M<br>3249<br>2117<br>3450<br>482<br>425<br>2468<br>3428<br>3490<br>711<br>3105<br>3425<br>3471<br>278<br>462M<br>488<br>2506<br>3386M<br>3453<br>3470 | 2198 3451 485 460 2741 3437 3508 1628 3107 3436 3473 304 463 693M 2542 3400 3454 3472 | | P | 1857D | 1860 | 1861M | 1865 | 1872 | 2445D | 2447 | 2448 | 2449 | 2450 | |----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------|----------------------------------------------------------|------------------------------|-------------|----------------------|----------------------| | | 2452 | 3360d | 336311 | 1110 | | | | | | | | params | 1116 | 1117 | 1118M | 1119 | 1357 | 1360 | 1370M | 1372 | 1376 | 1377 | | • | 2101 | 2236d | 2303 | 2476 | 2551 | 2552 | 2573 | 2611 | 2627 | 2629 | | | 2634 | 2635 | 2643 | 2644 | 2701 | 2752 | 2756 | 2775 | 2777 | 3189 | | passivate | 1911 | 3027 | 3076 | 3137 | 3260 | 3297 | 3314 | • | | | | pid | 2044 | 2227D | 2273 | 2280 | 2298 | 2333 ` | 2356 | 2419 | 2434 | 2452 | | | 2466 | 2503 | 2541 | 2561 | 2574 | 2599 | 2604 | 2639 | 2740 | 2881D | | | 2884 | 2937 | 3393 | 3404 | | | | - | | | | pr | 1865 | 2206D | 2209 | 2210 | 2211 | 2213 | 2328D | 2333M | 2356 | 2366M | | • | 2657 | 2671d | 2889D | 2964M | 296611 | 3039D | 3050 | 3051 | 3057 | 3073 | | | 3080 | 3085 | | _• | | | 0020 | 3031 | 3037 | 5075 | | pred | 1309 | 1329 | | | | | | | | | | prev | 1707 | 1327 | | | | | | | | | | | 291D | 301D | 316D | 366D | 402D | / 20D | / 5 715 | 501 | 500 | | | print | | | 3100 | 3000 | 4020 | 420D | 457บ | 501 | 508 | | | printfile | 105 | 172 | | | | | | | | | | priority | 249D | 251M | 252 | 1429 | 1683 | 1690 | 2232D | 2294 | 2705 | 2766 | | | 2782 | | | | | | | | | | | priority_tex | 81D | 115 | 116 | 117 | 118 | 273 | | | | | | process | 573 | 2994 | 3035 | 3112 | 3151 | 3271 | | | | | | processor | 1112 | 1249 | 1273 | 1285 | 1286 | 1344 | 1416 | 1425 | 1429 | 1440 | | _ | 1578 | 1583 | 1584 | 1585 | 1642 | 1653 | 1681 | 1682 | 1683 | 1684 | | | 1690 | 1697 | 1872 | 1984D | 2044 | 2052 | 2076 | 2091 | 2101 | 2117 | | | 2118 | 2126 | 2419 | 2425 | 2431 | 2434 | 2447 | 2466 | 2476 | 2503 | | | 2509 | 2541 | 2545 | 2551 | 2552 | 2556 | 2561 | 2573 | 2574 | 2599 | | | 2601 | 2602 | 2604 | 2611 | 2620 | 2625 | | | | | | | | | | | | | 2639 | 2643 | 2644 | 2701 | | | 2705 | 2740 | 2752 | 2756 | 2766 | 2775 | 2776 | 2777 | 2782 | 2904 | | | 2906 | 2908 | 2916 | 2937 | 3189 | 3393 | 1001 | | | | | ptime | 182D | 194 | 266 | 693 | 727 | 1629 | 1901 | 2422 | 2452 | 2466 | | • | 2506 | 2542 | 2598 | 2738 | 2825 | 3069 | 3089 | | | | | ptr | 264D | 274 | 276 | 278 | 280M | 497D | 498 | 499 | 501 | 502M | | | 506 | 507 | 508 | 509M | 514D | 515 | 516 | 517 | 518M | 520 | | | 521 | 522 | 52311 | 1307D | 1309 | 1310 | 1313 | 1314 | 1318M | 1322 | | | 1323 | 1329m | 1610D | 1623 | 1626 | 1629 | 1633 | 1638 | 1672M | 1673 | | | 1676 | 1714 | 1723 | 1727 | 1832 | 1859 | 1860 | 1865 | 1867 | 2961D | | | 2962 | 2963m | 2964 | 3162D | 3245 | 3246 | 3247M | 3248 | 3254 | 3257 | | | 3370d | 3390 | 3391 | 3393 | 3394M | 3401 | 3402 | 3404 | 3405M | 3231 | | putative ret | 2111D | 2118 | 2779 | 3373 | 337411 | 3401 | 3402 | 3404 | J40JH | | | <u> </u> | | | | 2124 | 2410 | 2420 | 2421 | 25.02 | 2501 | 2505 | | putint | 211. | 2044 | 2045 | 2134 | 2419 | 2420 | 2421 | 2503 | 2504 | 2505 | | | 2541 | 14000 | 1700 | 100/ | | • | | | | | | put_in_ready | 1403 | 1409D | 1788 | 1884 | | | | | | | | p_cost | 1089D | 1156 | 1161 | 1162 | | | | | | | | p_key | 1819 | 2312D | | | | | | | | | | p_seg_list | 1355 | 1360 | 1363 | 1365 | 2288D | 2305 | | | | | | p_seg_listc | 1814 | 2288 | 2305 | 2312D | | | | | | | | p site | | | 1155 | 1156 | 1157 | 1158 | 1162 | 1197 | 1257 | 2012D | | | 1120 | 1153 | | | | 001/0 | | | | | | p size | | 1153<br>1117M | 1121 | 1124 | 1257 | 20140 | | | | | | p_size | 1114 | 1117M | 1121 | 1124<br>232 | 1257<br>237M | 2014D<br>242 | 246 | 252 | 274 | 1309 | | p_size<br>q | 1114<br>219D | 1117M<br>224 | | 1124<br>232 | 1257<br>237M | 2014 <u>p</u><br>242 | 246 | 252 | 274 | 1309 | | p_size<br>q<br>q4space | 1114<br>219D<br>677D | 1117M<br>224<br>1292 | 1121<br>225 | | | | 246 | 252 | 274 | 1309 | | p_size<br>q<br>q4space<br>qempty | 1114<br>219D<br>677D<br>239D | 1117M<br>224<br>1292<br>243 | 1121<br>225<br>270 | | | | 246 | 252 | 274 | 1309 | | p_size<br>q<br>q4space<br>qempty<br>qf | 1114<br>219D<br>677D<br>239D<br>537D | 1117M<br>224<br>1292<br>243<br>889 | 1121<br>225<br>270<br>935 | 232 | 237M | 242 | | | | | | p_size<br>q<br>q4space<br>qempty | 1114<br>219D<br>677D<br>239D<br>537D<br>879M | 1117M<br>224<br>1292<br>243<br>889<br>889 | 1121<br>225<br>270<br>935<br>932M | 232<br>935 | 237M<br>952D | | 246<br>1076 | 252<br>1240 | 274<br>1270 | 1309<br>1897 | | p_size<br>q<br>q4space<br>qempty<br>qf<br>qfs | 1114<br>219D<br>677D<br>239D<br>537D<br>879M<br>2925m | 1117M<br>224<br>1292<br>243<br>889<br>889<br>2943m | 1121<br>225<br>270<br>935 | 232 | 237M | 242 | | | | | | p_size<br>q<br>q4space<br>qempty<br>qf<br>qfs<br>qf_max | 1114<br>219D<br>677D<br>239D<br>537D<br>879M<br>2925m<br>998D | 1117M<br>224<br>1292<br>243<br>889<br>889<br>2943m<br>1011 | 1121<br>225<br>270<br>935<br>932M | 232<br>935 | 237M<br>952D | 242 | | | | | | p_size<br>q<br>q4space<br>qempty<br>qf<br>qfs<br>qf_max<br>qf_min | 1114<br>219D<br>677D<br>239D<br>537D<br>879M<br>2925m<br>998D<br>998D | 1117M<br>224<br>1292<br>243<br>889<br>889<br>2943m<br>1011 | 270<br>935<br>932N<br>2951M | 232<br>935<br>2969M | 237M<br>952D<br>3419 | 1013 | | | | | | p_size q q4space qempty qf qfs qf_max qf_min qhead | 1114<br>219D<br>677D<br>239D<br>537D<br>879M<br>2925m<br>998D<br>998D<br>249D | 1117M<br>224<br>1292<br>243<br>889<br>889<br>2943m<br>1011<br>1010<br>252 | 270<br>935<br>932M<br>2951M | 232<br>935<br>2969M<br>268 | 237M<br>952D<br>3419<br>270 | 242<br>1013<br>274 | | | | | | p_size q q4space qempty qf qfs qf_max qf_min qhead qheadc | 1114<br>219D<br>677D<br>239D<br>537D<br>879M<br>2925m<br>998D<br>998D<br>249D<br>217D | 1117M<br>224<br>1292<br>243<br>889<br>889<br>2943m<br>1011<br>1010<br>252<br>250 | 270<br>935<br>932M<br>2951M | 232<br>935<br>2969M<br>268<br>576 | 237M<br>952D<br>3419<br>270<br>610 | 242<br>1013<br>274<br>611 | 1076 | 1240 | 1270 | 1897 | | p_size q q4space qempty qf qfs qf_max qf_min qhead | 1114<br>219D<br>677D<br>239D<br>537D<br>879M<br>2925m<br>998D<br>998D<br>249D<br>217D<br>249D | 1117M<br>224<br>1292<br>243<br>889<br>889<br>2943m<br>1011<br>1010<br>252<br>250<br>684 | 257D<br>257D<br>270<br>270<br>270<br>2951M | 935<br>2969M<br>268<br>576<br>870 | 237M<br>952D<br>3419<br>270<br>610<br>874 | 242<br>1013<br>274<br>611<br>878 | 1076<br>882 | 1240<br>912 | 1270 | | | p_size q q4space qempty qf qfs qf_max qf_min qhead qheadc | 1114<br>219D<br>677D<br>239D<br>537D<br>879M<br>2925m<br>998D<br>998D<br>249D<br>217D | 1117M<br>224<br>1292<br>243<br>889<br>889<br>2943m<br>1011<br>1010<br>252<br>250 | 270<br>935<br>932M<br>2951M | 232<br>935<br>2969M<br>268<br>576 | 237M<br>952D<br>3419<br>270<br>610 | 242<br>1013<br>274<br>611 | 1076 | 1240 | 1270 | 1897 | | p_size q q4space qempty qf qfs qf_max qf_min qhead qheadc | 1114<br>219D<br>677D<br>239D<br>537D<br>879M<br>2925m<br>998D<br>998D<br>249D<br>217D<br>249D<br>1429<br>2966 | 1117M<br>224<br>1292<br>243<br>889<br>889<br>2943m<br>1011<br>1010<br>252<br>250<br>684 | 257D<br>257D<br>270<br>270<br>270<br>2951M | 935<br>2969M<br>268<br>576<br>870 | 237M<br>952D<br>3419<br>270<br>610<br>874 | 242<br>1013<br>274<br>611<br>878 | 1076<br>882 | 1240<br>912 | 1270 | 1897 | | p_size q q4space qempty qf qfs qfs qf_max qf_min qhead qheadc queue | 1114<br>219D<br>677D<br>239D<br>537D<br>879M<br>2925m<br>998D<br>998D<br>249D<br>217D<br>249D<br>1429 | 1117M<br>224<br>1292<br>243<br>889<br>889<br>2943m<br>1011<br>1010<br>252<br>250<br>684<br>1690 | 257D<br>257D<br>257D<br>257D<br>257D<br>257D<br>259<br>723 | 232<br>935<br>2969M<br>268<br>576<br>870<br>1711 | 237M<br>952D<br>3419<br>270<br>610<br>874 | 242<br>1013<br>274<br>611<br>878 | 1076<br>882 | 1240<br>912 | 1270 | 1897 | | p_size q q4space qempty qf qfs qf_max qf_min qhead qheadc queue q analysis | 1114<br>219D<br>677D<br>239D<br>537D<br>879M<br>2925m<br>998D<br>998D<br>249D<br>217D<br>249D<br>1429<br>2966<br>257D | 1117M<br>224<br>1292<br>243<br>889<br>889<br>2943m<br>1011<br>1010<br>252<br>250<br>684<br>1690<br>3022<br>3375 | 2570<br>935<br>932M<br>2951M<br>2951M<br>257D<br>259<br>723<br>1695<br>3065<br>3376 | 232<br>935<br>2969M<br>268<br>576<br>870<br>1711 | 237M<br>952D<br>3419<br>270<br>610<br>874 | 242<br>1013<br>274<br>611<br>878 | 1076<br>882 | 1240<br>912 | 1270 | 1897 | | p_size q q4space qempty qf qfs qf_max qf_min qhead qheadc queue q_analysis q_trace | 1114<br>219D<br>677D<br>239D<br>537D<br>879M<br>2925m<br>998D<br>249D<br>217D<br>249D<br>1429<br>2966<br>257D<br>73D | 1117M<br>224<br>1292<br>243<br>889<br>889<br>2943m<br>1011<br>1010<br>252<br>250<br>684<br>1690<br>3022<br>3375 - | 2570<br>935<br>932M<br>2951M<br>257D<br>259<br>723<br>1695<br>3065<br>3376<br>1626 | 232<br>935<br>2969M<br>268<br>576<br>870<br>1711<br>3131 | 237M<br>952D<br>3419<br>270<br>610<br>874 | 242<br>1013<br>274<br>611<br>878 | 1076<br>882 | 1240<br>912 | 1270 | 1897 | | p_size q q4space qempty qf qfs qf_max qf_min qhead qheadc queue q_analysis q_trace r | 1114<br>219D<br>677D<br>239D<br>537D<br>879M<br>2925m<br>998D<br>249D<br>217D<br>249D<br>1429<br>2966<br>257D<br>73D<br>2903D | 1117M<br>224<br>1292<br>243<br>889<br>889<br>2943m<br>1011<br>1010<br>252<br>250<br>684<br>1690<br>3022<br>3375<br>170<br>2904 | 2570<br>935<br>932M<br>2951M<br>257D<br>259<br>723<br>1695<br>3065<br>3376<br>1626<br>2906 | 232<br>935<br>2969M<br>268<br>576<br>870<br>1711 | 237M<br>952D<br>3419<br>270<br>610<br>874 | 242<br>1013<br>274<br>611<br>878 | 1076<br>882 | 1240<br>912 | 1270 | 1897 | | p_size q q4space qempty qf qfs qf_max qf_min qhead qheadc queue q_analysis q_trace r r2 | 1114<br>219D<br>677D<br>239D<br>537D<br>879M<br>2925m<br>998D<br>298D<br>249D<br>217D<br>249D<br>1429<br>2966<br>257D<br>73D<br>2903D<br>459D | 1117M<br>224<br>1292<br>243<br>889<br>889<br>2943m<br>1011<br>1010<br>252<br>250<br>684<br>1690<br>3022<br>3375<br>170<br>2904<br>473 | 2570<br>935<br>932M<br>2951M<br>257D<br>257D<br>259<br>723<br>1695<br>3065<br>3376<br>1626<br>2906<br>487 | 232<br>935<br>2969M<br>268<br>576<br>870<br>1711<br>3131 | 237M<br>952D<br>3419<br>270<br>610<br>874<br>1773 | 242<br>1013<br>274<br>611<br>878<br>2106 | 1076<br>882<br>2193 | 1240<br>912 | 1270 | 1897 | | p_size q q4space qempty qf qfs qf_max qf_min qhead queue q_analysis q_trace r r2 randint | 1114<br>219D<br>677D<br>239D<br>537D<br>879M<br>2925m<br>998D<br>998D<br>249D<br>217D<br>249D<br>1429<br>2966<br>257D<br>73D<br>2903D<br>459D<br>2401 | 1117M<br>224<br>1292<br>243<br>889<br>889<br>2943m<br>1011<br>1010<br>252<br>250<br>684<br>1690<br>3022<br>3375<br>170<br>2904<br>473<br>2450 | 257D<br>270<br>935<br>932M<br>2951M<br>257D<br>257D<br>259<br>723<br>1695<br>3065<br>3376<br>1626<br>2906<br>487<br>2602 | 232<br>935<br>2969M<br>268<br>576<br>870<br>1711<br>3131<br>2907 | 237M<br>952D<br>3419<br>270<br>610<br>874 | 242<br>1013<br>274<br>611<br>878 | 1076<br>882 | 1240<br>912 | 1270 | 1897 | | p_size q q4space qempty qf qfs qf_max qf_min qhead qhead queue q_analysis q_trace r r2 randint random_seed | 1114<br>219D<br>677D<br>239D<br>537D<br>879M<br>2925m<br>998D<br>998D<br>249D<br>217D<br>249D<br>1429<br>2966<br>257D<br>73D<br>2903D<br>459D<br>2401<br>102D | 1117M<br>224<br>1292<br>243<br>889<br>889<br>2943m<br>1011<br>1010<br>252<br>250<br>684<br>1690<br>3022<br>3375<br>170<br>2904<br>473<br>2450<br>156 | 257D<br>259<br>270<br>935<br>932M<br>2951M<br>257D<br>259<br>723<br>1695<br>3065<br>3376<br>1626<br>2906<br>487<br>2602<br>2383 | 232<br>935<br>2969M<br>268<br>576<br>870<br>1711<br>3131<br>2907<br>2657<br>3487 | 237M<br>952D<br>3419<br>270<br>610<br>874<br>1773 | 242<br>1013<br>274<br>611<br>878<br>2106 | 1076<br>882<br>2193 | 1240<br>912 | 1270 | 1897 | | p_size q q4space qempty qf qfs qf_max qf_min qhead qheadc queue q_analysis q_trace r r2 randint random_seed read | 1114<br>219D<br>677D<br>239D<br>537D<br>879M<br>2925m<br>998D<br>998D<br>249D<br>217D<br>249D<br>1429<br>2966<br>257D<br>73D<br>2903D<br>459D<br>2401<br>102D<br>3148D | 1117M<br>224<br>1292<br>243<br>889<br>889<br>2943m<br>1011<br>1010<br>252<br>250<br>684<br>1690<br>3022<br>3375<br>170<br>2904<br>473<br>2450<br>156<br>3188 | 257D<br>257D<br>257D<br>257D<br>257D<br>257D<br>257D<br>259<br>723<br>1695<br>3065<br>3376<br>1626<br>2906<br>487<br>2602<br>2383<br>3201 | 232<br>935<br>2969M<br>268<br>576<br>870<br>1711<br>3131<br>2907<br>2657<br>3487<br>3302 | 237M<br>952D<br>3419<br>270<br>610<br>874<br>1773 | 242<br>1013<br>274<br>611<br>878<br>2106 | 1076<br>882<br>2193 | 1240<br>912 | 1270 | 1897 | | p_size q q4space qempty qf qfs qf_max qf_min qhead qheadc queue q_analysis q_trace r r2 randint random_seed read read_next | 1114<br>219D<br>677D<br>239D<br>537D<br>879M<br>2925m<br>998D<br>249D<br>217D<br>249D<br>1429<br>2966<br>257D<br>73D<br>2903D<br>459D<br>2401<br>102D<br>3148D<br>2675D | 1117M<br>224<br>1292<br>243<br>889<br>889<br>2943m<br>1011<br>1010<br>252<br>250<br>684<br>1690<br>3022<br>3375<br>170<br>2904<br>473<br>2450<br>156<br>3188<br>2809 | 2570<br>270<br>935<br>932M<br>2951M<br>257D<br>259<br>723<br>1695<br>3065<br>3376<br>1626<br>2906<br>487<br>2602<br>2383<br>3201<br>2810 | 232<br>935<br>2969M<br>268<br>576<br>870<br>1711<br>3131<br>2907<br>2657<br>3487<br>3302<br>2812 | 237M<br>952D<br>3419<br>270<br>610<br>874<br>1773 | 242<br>1013<br>274<br>611<br>878<br>2106 | 1076<br>882<br>2193 | 1240<br>912 | 1270 | 1897 | | p_size q q4space qempty qf qfs qf_max qf_min qhead qheadc queue q_analysis q_trace r r2 randint random_seed read read_next register_m_u | 1114<br>219D<br>677D<br>239D<br>537D<br>879M<br>2925m<br>998D<br>998D<br>249D<br>217D<br>249D<br>1429<br>2966<br>257D<br>73D<br>2903D<br>459D<br>2401<br>102D<br>3148D<br>2675D<br>663 | 1117M<br>224<br>1292<br>243<br>889<br>889<br>2943m<br>1011<br>1010<br>252<br>250<br>684<br>1690<br>3022<br>3375<br>170<br>2904<br>473<br>2450<br>156<br>3188<br>2809<br>707 | 257D<br>270 935 932M<br>2951M<br>257D<br>259 723 1695 3065 3376 1626 2906 487 2602 2383 3201 2810 887 | 232<br>935<br>2969M<br>268<br>576<br>870<br>1711<br>3131<br>2907<br>2657<br>3487<br>3302 | 237M<br>952D<br>3419<br>270<br>610<br>874<br>1773 | 242<br>1013<br>274<br>611<br>878<br>2106 | 1076<br>882<br>2193 | 1240<br>912 | 1270 | 1897 | | p_size q q4space qempty qf qfs qfs qf_max qf_min qhead qheadc queue q_analysis q_trace r r2 randint random_seed read read read read rester m_u regression | 1114<br>219D<br>677D<br>239D<br>537D<br>879M<br>2925m<br>998D<br>998D<br>249D<br>217D<br>249D<br>1429<br>2966<br>257D<br>73D<br>2903D<br>459D<br>2401<br>102D<br>3148D<br>2675D<br>663<br>437D | 1117M<br>224<br>1292<br>243<br>889<br>889<br>2943m<br>1011<br>1010<br>252<br>250<br>684<br>1690<br>3022<br>3375<br>170<br>2904<br>473<br>2450<br>156<br>3188<br>2809<br>707<br>570 | 257D<br>270<br>935<br>932M<br>2951M<br>257D<br>257D<br>259<br>723<br>1695<br>3065<br>3376<br>1626<br>2906<br>487<br>2602<br>2383<br>3201<br>2810<br>887<br>3351 | 232<br>935<br>2969M<br>268<br>576<br>870<br>1711<br>3131<br>2907<br>2657<br>3487<br>3302<br>2812<br>958D | 237M<br>952D<br>3419<br>270<br>610<br>874<br>1773 | 242<br>1013<br>274<br>611<br>878<br>2106 | 1076<br>882<br>2193 | 1240<br>912 | 1270 | 1897 | | p_size q q4space qempty qf qfs qfs qf_max qf_min qhead qheadc queue q_analysis q_trace r r2 randint random_seed read read read read_next register_m_u regression release | 1114<br>219D<br>677D<br>239D<br>537D<br>879M<br>2925m<br>998D<br>998D<br>249D<br>217D<br>249D<br>1429<br>2966<br>257D<br>73D<br>2903D<br>459D<br>2401<br>102D<br>3148D<br>2675D<br>663<br>437D<br>700D | 1117M<br>224<br>1292<br>243<br>889<br>889<br>2943m<br>1011<br>1010<br>252<br>250<br>684<br>1690<br>3022<br>3375<br>170<br>2904<br>473<br>2450<br>156<br>3188<br>2809<br>707<br>570<br>842 | 257D<br>270<br>935<br>932M<br>2951M<br>257D<br>259<br>723<br>1695<br>3065<br>3376<br>1626<br>2906<br>487<br>2602<br>2383<br>3201<br>2810<br>887<br>3351<br>1501 | 232<br>935<br>2969M<br>268<br>576<br>870<br>1711<br>3131<br>2907<br>2657<br>3487<br>3302<br>2812 | 237M<br>952D<br>3419<br>270<br>610<br>874<br>1773 | 242<br>1013<br>274<br>611<br>878<br>2106 | 1076<br>882<br>2193 | 1240<br>912 | 1270 | 1897 | | p_size q q4space qempty qf qfs qfs qf_max qf_min qhead qheadc queue q_analysis q_trace r r2 randint random_seed read read read read rester m_u regression | 1114<br>219D<br>677D<br>239D<br>537D<br>879M<br>2925m<br>998D<br>998D<br>249D<br>217D<br>249D<br>1429<br>2966<br>257D<br>73D<br>2903D<br>459D<br>2401<br>102D<br>3148D<br>2675D<br>663<br>437D<br>700D<br>3119D | 1117M<br>224<br>1292<br>243<br>889<br>889<br>2943m<br>1011<br>1010<br>252<br>250<br>684<br>1690<br>3022<br>3375<br>170<br>2904<br>473<br>2450<br>156<br>3188<br>2809<br>707<br>570<br>842<br>3125 | 257D<br>270<br>935<br>932M<br>2951M<br>257D<br>259<br>723<br>1695<br>3065<br>3376<br>1626<br>2906<br>487<br>2602<br>2383<br>3201<br>2810<br>887<br>3351<br>1501<br>3127 | 232<br>935<br>2969M<br>268<br>576<br>870<br>1711<br>3131<br>2907<br>2657<br>3487<br>3302<br>2812<br>958D<br>1521 | 237M<br>952D<br>3419<br>270<br>610<br>874<br>1773 | 242<br>1013<br>274<br>611<br>878<br>2106 | 1076<br>882<br>2193 | 1240<br>912 | 1270 | 1897 | | p_size q q4space qempty qf qfs qfs qf_max qf_min qhead qheadc queue q_analysis q_trace r r2 randint random_seed read read read read_next register_m_u regression release | 1114<br>219D<br>677D<br>239D<br>537D<br>879M<br>2925m<br>998D<br>249D<br>217D<br>249D<br>1429<br>2966<br>257D<br>73D<br>2903D<br>459D<br>2401<br>102D<br>3148D<br>2675D<br>663<br>437D<br>700D<br>3119D<br>3041D | 1117M<br>224<br>1292<br>243<br>889<br>889<br>2943m<br>1011<br>1010<br>252<br>250<br>684<br>1690<br>3022<br>3375<br>170<br>2904<br>473<br>2450<br>156<br>3188<br>2809<br>707<br>570<br>842<br>3125<br>3048 | 257D<br>270<br>935<br>932M<br>2951M<br>257D<br>259<br>723<br>1695<br>3065<br>3376<br>1626<br>2906<br>487<br>2602<br>2383<br>3201<br>2810<br>887<br>3351<br>1501 | 232<br>935<br>2969M<br>268<br>576<br>870<br>1711<br>3131<br>2907<br>2657<br>3487<br>3302<br>2812<br>958D | 237M<br>952D<br>3419<br>270<br>610<br>874<br>1773 | 242<br>1013<br>274<br>611<br>878<br>2106 | 1076<br>882<br>2193 | 1240<br>912 | 1270 | 1897 | | q 4space q 4space qempty qf qfs qf_max qf_min qhead qheadc queue q_analysis q_trace r r2 randint random_seed read read_next register_m_u regression release remaining | 1114<br>219D<br>677D<br>239D<br>537D<br>879M<br>2925m<br>998D<br>998D<br>249D<br>217D<br>249D<br>1429<br>2966<br>257D<br>73D<br>2903D<br>459D<br>2401<br>102D<br>3148D<br>2675D<br>663<br>437D<br>700D<br>3119D | 1117M<br>224<br>1292<br>243<br>889<br>889<br>2943m<br>1011<br>1010<br>252<br>250<br>684<br>1690<br>3022<br>3375<br>170<br>2904<br>473<br>2450<br>156<br>3188<br>2809<br>707<br>570<br>842<br>3125<br>3048<br>2847 | 257D<br>270<br>935<br>932M<br>2951M<br>257D<br>259<br>723<br>1695<br>3065<br>3376<br>1626<br>2906<br>487<br>2602<br>2383<br>3201<br>2810<br>887<br>3351<br>1501<br>3127 | 232<br>935<br>2969M<br>268<br>576<br>870<br>1711<br>3131<br>2907<br>2657<br>3487<br>3302<br>2812<br>958D<br>1521 | 237M<br>952D<br>3419<br>270<br>610<br>874<br>1773 | 242<br>1013<br>274<br>611<br>878<br>2106 | 1076<br>882<br>2193 | 1240<br>912 | 1270 | 1897 | | q 4space q 4space qempty qf qfs qf_max qf_min qhead qheadc queue q_analysis q_trace r r2 randint random_seed read read_next regression release remaining response_tim | 1114<br>219D<br>677D<br>239D<br>537D<br>879M<br>2925m<br>998D<br>249D<br>217D<br>249D<br>1429<br>2966<br>257D<br>73D<br>2903D<br>459D<br>2401<br>102D<br>3148D<br>2675D<br>663<br>437D<br>700D<br>3119D<br>3041D | 1117M<br>224<br>1292<br>243<br>889<br>889<br>2943m<br>1011<br>1010<br>252<br>250<br>684<br>1690<br>3022<br>3375<br>170<br>2904<br>473<br>2450<br>156<br>3188<br>2809<br>707<br>570<br>842<br>3125<br>3048 | 257D<br>270<br>935<br>932M<br>2951M<br>257D<br>259<br>723<br>1695<br>3065<br>3376<br>1626<br>2906<br>487<br>2602<br>2383<br>3201<br>2810<br>887<br>3351<br>1501<br>3127 | 232<br>935<br>2969M<br>268<br>576<br>870<br>1711<br>3131<br>2907<br>2657<br>3487<br>3302<br>2812<br>958D<br>1521 | 237M<br>952D<br>3419<br>270<br>610<br>874<br>1773 | 242<br>1013<br>274<br>611<br>878<br>2106 | 1076<br>882<br>2193 | 1240<br>912 | 1270 | 1897 | | q size q q4space qempty qf qfs qfs qf_max qf_min qhead qheadc queue q_analysis q_trace r r2 randint random_seed read read_next register_m_u regression release remaining response_tim restart_proc | 1114<br>219D<br>677D<br>239D<br>537D<br>879M<br>2925m<br>998D<br>249D<br>217D<br>249D<br>1429<br>2966<br>257D<br>73D<br>2903D<br>459D<br>2401<br>102D<br>3148D<br>2675D<br>663<br>437D<br>700D<br>3119D<br>3041D<br>2185D | 1117M<br>224<br>1292<br>243<br>889<br>889<br>2943m<br>1011<br>1010<br>252<br>250<br>684<br>1690<br>3022<br>3375<br>170<br>2904<br>473<br>2450<br>156<br>3188<br>2809<br>707<br>570<br>842<br>3125<br>3048<br>2847 | 2570<br>270<br>935<br>932M<br>2951M<br>257D<br>259<br>723<br>1695<br>3065<br>3376<br>1626<br>2906<br>487<br>2602<br>2383<br>3201<br>2810<br>887<br>3351<br>1501<br>3127<br>3075 | 232 935 2969M 268 576 870 1711 3131 2907 2657 3487 3302 2812 958D 1521 3077 | 237M<br>952D<br>3419<br>270<br>610<br>874<br>1773<br>2906 | 242<br>1013<br>274<br>611<br>878<br>2106 | 1076<br>882<br>2193 | 1240<br>912 | 1270 | 1897 | | q size q q4space qempty qf qfs qf max qf_min qhead qheadc queue q_analysis q_trace r r2 randint random_seed read read read next register_m_u regression release remaining response_tim restart_proc results | 1114<br>219D<br>677D<br>239D<br>537D<br>879M<br>2925m<br>998D<br>998D<br>249D<br>217D<br>249D<br>1429<br>2966<br>257D<br>73D<br>2903D<br>459D<br>2401<br>102D<br>3148D<br>2675D<br>663<br>437D<br>700D<br>3119D<br>3041D<br>2185D<br>105D | 1117M<br>224<br>1292<br>243<br>889<br>889<br>2943m<br>1011<br>1010<br>252<br>250<br>684<br>1690<br>3022<br>3375<br>170<br>2904<br>473<br>2450<br>156<br>3188<br>2809<br>707<br>570<br>842<br>3125<br>3048<br>2847<br>172 | 257D<br>270<br>935<br>932M<br>2951M<br>257D<br>259<br>723<br>1695<br>3065<br>3376<br>1626<br>2906<br>487<br>2602<br>2383<br>3201<br>2810<br>887<br>3351<br>1501<br>3127<br>3075 | 232<br>935<br>2969M<br>268<br>576<br>870<br>1711<br>3131<br>2907<br>2657<br>3487<br>3302<br>2812<br>958D<br>1521<br>3077<br>175<br>2104 | 237M<br>952D<br>3419<br>270<br>610<br>874<br>1773<br>2906<br>2816 | 242<br>1013<br>274<br>611<br>878<br>2106 | 1076<br>882<br>2193 | 1240<br>912 | 1270 | 1897 | | q size q q4space qempty qf qfs qf_max qf_min qhead qheadc queue q_analysis q_trace r r2 randint random_seed read read read read reat register_m_u regression release remaining response_tim restart_proc results retire | 1114<br>219D<br>677D<br>239D<br>537D<br>879M<br>2925m<br>998D<br>998D<br>249D<br>217D<br>249D<br>1429<br>2966<br>257D<br>73D<br>2903D<br>459D<br>2401<br>102D<br>3148D<br>2675D<br>663<br>437D<br>700D<br>3119D<br>3041D<br>2185D<br>105D | 1117M<br>224<br>1292<br>243<br>889<br>889<br>2943m<br>1011<br>1010<br>252<br>250<br>684<br>1690<br>3022<br>3375<br>170<br>2904<br>473<br>2450<br>156<br>3188<br>2809<br>707<br>570<br>842<br>3125<br>3048<br>2847<br>172<br>1436D<br>821 | 257D<br>270<br>935<br>932M<br>2951M<br>257D<br>259<br>723<br>1695<br>3065<br>3376<br>1626<br>2906<br>487<br>2602<br>2383<br>3201<br>2810<br>887<br>3351<br>1501<br>3127<br>3075 | 232 935 2969M 268 576 870 1711 3131 2907 2657 3487 3302 2812 958D 1521 3077 175 | 237M 952D 3419 270 610 874 1773 2906 2816 | 242<br>1013<br>274<br>611<br>878<br>2106<br>2908<br>2832 | 1076<br>882<br>2193<br>3285M | 912<br>2716 | 1270<br>1323<br>2920 | 1897<br>1426<br>2950 | | q 4space q 4space qempty qf qfs qf_max qf_min qhead qheadc queue q_analysis q_trace r r2 randint random_seed read read_next register m_u regression release remaining response_tim restart_proc results retire retrieve return | 1114<br>219D<br>677D<br>239D<br>537D<br>879M<br>2925m<br>998D<br>249D<br>217D<br>249D<br>1429<br>2966<br>257D<br>73D<br>2903D<br>459D<br>2401<br>102D<br>3148D<br>2675D<br>663<br>437D<br>700D<br>3119D<br>3041D<br>2185D<br>105D<br>1322<br>807D<br>2079D | 1117M<br>224<br>1292<br>243<br>889<br>889<br>2943m<br>1011<br>1010<br>252<br>250<br>684<br>1690<br>3022<br>3375<br>170<br>2904<br>473<br>2450<br>156<br>3188<br>2809<br>707<br>570<br>842<br>3125<br>3048<br>2847<br>172<br>1436D<br>821<br>2091 | 257D<br>270<br>935<br>932M<br>2951M<br>257D<br>259<br>723<br>1695<br>3065<br>3376<br>1626<br>2906<br>487<br>2602<br>2383<br>3201<br>2810<br>887<br>3351<br>1501<br>3127<br>3075 | 232 935 2969M 268 576 870 1711 3131 2907 2657 3487 3302 2812 958D 1521 3077 175 2104 1808 | 237M<br>952D<br>3419<br>270<br>610<br>874<br>1773<br>2906<br>2816 | 242<br>1013<br>274<br>611<br>878<br>2106 | 1076<br>882<br>2193 | 1240<br>912 | 1270 | 1897 | | q 4space q 4space qempty qf qfs qf_max qf_min qhead qheadc queue q_analysis q_trace r r2 randint random_seed read read next register_m_u regression release remaining response_tim restart_proc results retire retrieve | 1114<br>219D<br>677D<br>239D<br>537D<br>879M<br>2925m<br>998D<br>998D<br>249D<br>217D<br>249D<br>1429<br>2966<br>257D<br>73D<br>2903D<br>459D<br>2401<br>102D<br>3148D<br>2675D<br>663<br>437D<br>700D<br>3119D<br>3041D<br>2185D<br>105D<br>1322<br>807D | 1117M<br>224<br>1292<br>243<br>889<br>889<br>2943m<br>1011<br>1010<br>252<br>250<br>684<br>1690<br>3022<br>3375<br>170<br>2904<br>473<br>2450<br>156<br>3188<br>2809<br>707<br>570<br>842<br>3125<br>3048<br>2847<br>172<br>1436D<br>821 | 257D<br>270<br>935<br>932M<br>2951M<br>257D<br>259<br>723<br>1695<br>3065<br>3376<br>1626<br>2906<br>487<br>2602<br>2383<br>3201<br>2810<br>887<br>3351<br>1501<br>3127<br>3075 | 232 935 2969M 268 576 870 1711 3131 2907 2657 3487 3302 2812 958D 1521 3077 175 2104 1808 | 237M 952D 3419 270 610 874 1773 2906 2816 | 242<br>1013<br>274<br>611<br>878<br>2106<br>2908<br>2832 | 1076<br>882<br>2193<br>3285M | 912<br>2716 | 1270<br>1323<br>2920 | 1897<br>1426<br>2950 | | rq1 | 2683D | 2725 | 2729 | 2730 | 2782 | 2832 | 2855 | 2866 | 3434 | | |----------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------| | rqstor | 1286 | 1355 | 1374 | 1397 | 1729 | 1731 | 1736 | 1740 | 1810 | 1819 | | - 1 | 1824 | 1966d | 2316D | 2323D | 2868 | 3176 | 3268D | 2740 | 1010 | 1019 | | rqst list | 1095 | 1770 | 1772 | 1949D | 1955 | 3170 | 32002 | | | | | rt | 3042D | 3072 | 3079M | 3083 | 3084 | 3085 | | | | | | rts | 1425 | 1642 | 1653 | 1682 | 1684 | 1697 | 2233D | 2295 | | | | running | 720 | 113 | 198 | 689 | 736 | 1614 | 1758 | 1760 | 2210 | 3012 | | | 3057 | 3060 | 3241 | 3298 | 3501 | 3504 | 1730 | 1700 | 2210 | 3012 | | runtt | 1573 | 1577 | 1580 | 1585 | 1586 | 2005D | 2032 | 2425 | 2435 | 2437 | | | 2459 | 2477 | 2509 | 2556 | 2559 | 2576 | 2613 | 2620 | 2624 | 2743 | | | 2770 | 2855 | 2875 | 2897 | 2931 | 2940 | 2975 | 2985 | 2024 | 2743 | | s | 824D | 827M | 828 | 829 | 832D | 837 | 839M | 842 | 1593D | 1597 | | | 1805d | 1808 | 1810 | | | 037 | 033 | 012 | 13730 | 1371 | | sameness | 1121 | 2253D | 2267M | | | | | | | | | · sd | 459D | 471 | 479 | 485 | | | | | | | | secretary | 2201D | 2213 | 2214 | 2215 | | | | | | | | secretaryc | 2172D | 2661 | 2886 | | | | | | | | | seek choice | 100D | 146 | 1058 | 1148 | 1179 | 1201 | 1203 | | | | | seek d site | 100D | 145 | 1047 | 1445 | 2031 | | | | | | | seg | 3145D | 3172 | 3176 | 3189 | 3203 | 3247 | 3288 | 3300 | 3304 | | | segmentc | 546D | 554 | 782 | 825 | 833 | 863 | 864 | 865 | 868 | 906 | | J | 1805 | 1846m | 1853 | 2061 | 2227 | 2328 | 2693 | 2695 | 3145 | 3197 | | | 3203 | | | | | | | | 52.15 | 3177 | | seg table | 782D | 820 | 827 | 841 | 1808 | 1819 | 1824 | 2375 | 3423M | | | send domain | 1454D | 1468 | 1476 | | | | | | - / | | | send message | 899D | 923 | 1054 | 1061 | 1173 | 1176 | 1199 | 1225 | 1347 | 1365 | | <b>–</b> " | 1377 | 1398 | 1459 | 1723 | 1727 | 1810 | 1819 | 1824 | 2695 | 2727 | | | 2730 | 2787 | | | | | | 101. | 2075 | -,-, | | send off | 1222D | 1241 | 1272 | | | | | | | | | service time | 1578 | 1583 | 2211 | 2282D | 2296 | | | | | | | set | 1642 | 3115D | | | | | | • | | | | setkey | 2332D | 2333 | 2341 | 2350 | | | | | | | | setpos | 3455 | 3462 | 3468 | 3474 | 3481 | 3488 | | | | | | settle time | 103D | 160 | 3497 | | | | | | | | | setup_disk_r | 2123D | 2433 | 2560 | 2602 | | | | | | | | shifts | 1227M | 1236 | 1237 | 1265 | 1314 | 1447 | 2001D | | | | | short comman | 567D | 3082 | 3347 | • | | _ | | | | | | signal_chann | 907 | 926D | 1837 | | | | | | | | | signal disk | 2689D | 2761 | 2817 | 2833 | 2841 | | | | | | | signal free | 3193 | 3206 | 3212D | 3256 | 3308 | | | | | | | signal read | 3222D | 3302 | | | | | | | | | | simple param | 2126 | 2239D | 2636 | 2776 | | | | | | | | simulation | 178 | | | | | | | | | | | sim time | 103D | 158 | 3458 | 3501 | 3510 | | | | | | | site | | | 000 | | 958D | 963M | 965 | 966 | 969 | 970 | | DICC | 546D | 553 | 829 | 839 | | 1078M | 1120 | | | | | 5100 | .972 | 553<br>984 | 829<br>992 | 1071D | 1076 | 10,011 | 1120 | 1130 | 1352 | 1365 | | | | | | | 1076<br>2025D | 2089 | | 1130<br>2142 | 1352<br>2182 | 1365<br>2189 | | | .972 | 984 | 992 | 1071D | | | 2103<br>2368M | 2142 | 2182 | 2189 | | 5710 | .972<br>1377 | 984<br>1385 | 992<br>1413 | 1071D<br>1752 | 2025D | 2089 | 2103 | 2142<br>2374 | 2182<br>2421 | 2189<br>2505 | | STCC . | .972<br>1377<br>2198 | 984<br>1385<br>2207 | 992<br>1413<br>2209 | 1071D<br>1752<br>2221 | 2025D<br>2303 | 2089<br>2333 | 2103<br>2368M | 2142 | 2182<br>2421<br>2777 | 2189<br>2505<br>2787 | | | .972<br>1377<br>2198<br>2552 | 984<br>1385<br>2207<br>2634 | 992<br>1413<br>2209<br>2644 | 1071D<br>1752<br>2221<br>2694 | 2025D<br>2303<br>2695 | 2089<br>2333<br>2716 | 2103<br>2368M<br>2727 | 2142<br>2374<br>2730 | 2182<br>2421 | 2189<br>2505 | | size | .972<br>1377<br>2198<br>2552<br>2812 | 984<br>1385<br>2207<br>2634<br>2872 | 992<br>1413<br>2209<br>2644<br>2877 | 1071D<br>1752<br>2221<br>2694 | 2025D<br>2303<br>2695 | 2089<br>2333<br>2716<br>2920 | 2103<br>2368M<br>2727<br>2925M | 2142<br>2374<br>2730<br>2942 | 2182<br>2421<br>2777<br>2943M | 2189<br>2505<br>2787<br>2947 | | | .972<br>1377<br>2198<br>2552<br>2812<br>2949 | 984<br>1385<br>2207<br>2634<br>2872<br>2965 | 992<br>1413<br>2209<br>2644<br>2877<br>2982 | 1071D<br>1752<br>2221<br>2694<br>2914 | 2025D<br>2303<br>2695<br>2918 | 2089<br>2333<br>2716 | 2103<br>2368M<br>2727 | 2142<br>2374<br>2730 | 2182<br>2421<br>2777<br>2943M<br>706 | 2189<br>2505<br>2787<br>2947 | | | .972<br>1377<br>2198<br>2552<br>2812<br>2949<br>533D | 984<br>1385<br>2207<br>2634<br>2872<br>2965<br>636 | 992<br>1413<br>2209<br>2644<br>2877<br>2982<br>647D | 1071D<br>1752<br>2221<br>2694<br>2914 | 2025D<br>2303<br>2695<br>2918 | 2089<br>2333<br>2716<br>2920 | 2103<br>2368M<br>2727<br>2925M | 2142<br>2374<br>2730<br>2942<br>700D | 2182<br>2421<br>2777<br>2943M | 2189<br>2505<br>2787<br>2947<br>842<br>1119 | | | .972<br>1377<br>2198<br>2552<br>2812<br>2949<br>533D<br>998d | 984<br>1385<br>2207<br>2634<br>2872<br>2965<br>636 | 992<br>1413<br>2209<br>2644<br>2877<br>2982<br>647D<br>1015 | 1071D<br>1752<br>2221<br>2694<br>2914<br>652M<br>1018 | 2025D<br>2303<br>2695<br>2918<br>656<br>1071D | 2089<br>2333<br>2716<br>2920<br>659<br>1078 | 2103<br>2368M<br>2727<br>2925M<br>661<br>1105 | 2142<br>2374<br>2730<br>2942<br>700D<br>1114 | 2182<br>2421<br>2777<br>2943M<br>706<br>1117 | 2189<br>2505<br>2787<br>2947<br>842<br>1119<br>2049 | | | .972<br>1377<br>2198<br>2552<br>2812<br>2949<br>533D<br>998d<br>1131 | 984<br>1385<br>2207<br>2634<br>2872<br>2965<br>636<br>1007<br>1136 | 992<br>1413<br>2209<br>2644<br>2877<br>2982<br>647D<br>1015<br>1473 | 1071D<br>1752<br>2221<br>2694<br>2914<br>652M<br>1018<br>1501 | 2025D<br>2303<br>2695<br>2918<br>656<br>1071D<br>1520 | 2089<br>2333<br>2716<br>2920<br>659<br>1078<br>1521 | 2103<br>2368M<br>2727<br>2925M<br>661<br>1105<br>1758 | 2142<br>2374<br>2730<br>2942<br>700D<br>1114<br>1969 | 2182<br>2421<br>2777<br>2943M<br>706<br>1117<br>1980<br>2352 | 2189<br>2505<br>2787<br>2947<br>842<br>1119<br>2049<br>2367M | | size | .972<br>1377<br>2198<br>2552<br>2812<br>2949<br>533D<br>998d<br>1131<br>2123d<br>2481<br>3288 | 984<br>1385<br>2207<br>2634<br>2872<br>2965<br>636<br>1007<br>1136<br>2126<br>2580<br>3300 | 992<br>1413<br>2209<br>2644<br>2877<br>2982<br>647D<br>1015<br>1473<br>2169<br>2648<br>3369D | 1071D<br>1752<br>2221<br>2694<br>2914<br>652M<br>1018<br>1501<br>2210<br>3007<br>3377 | 2025D<br>2303<br>2695<br>2918<br>656<br>1071D<br>1520<br>2297 | 2089<br>2333<br>2716<br>2920<br>659<br>1078<br>1521<br>2318 | 2103<br>2368M<br>2727<br>2925M<br>661<br>1105<br>1758<br>2325 | 2142<br>2374<br>2730<br>2942<br>700D<br>1114<br>1969<br>2343 | 2182<br>2421<br>2777<br>2943M<br>706<br>1117<br>1980 | 2189<br>2505<br>2787<br>2947<br>842<br>1119<br>2049 | | | .972<br>1377<br>2198<br>2552<br>2812<br>2949<br>533D<br>998d<br>1131<br>2123d<br>2481<br>3288<br>87D | 984<br>1385<br>2207<br>2634<br>2872<br>2965<br>636<br>1007<br>1136<br>2126<br>2580 | 992<br>1413<br>2209<br>2644<br>2877<br>2982<br>647D<br>1015<br>1473<br>2169<br>2648 | 1071D<br>1752<br>2221<br>2694<br>2914<br>652M<br>1018<br>1501<br>2210<br>3007 | 2025D<br>2303<br>2695<br>2918<br>656<br>1071D<br>1520<br>2297<br>3013 | 2089<br>2333<br>2716<br>2920<br>659<br>1078<br>1521<br>2318<br>3014 | 2103<br>2368M<br>2727<br>2925M<br>661<br>1105<br>1758<br>2325<br>3057 | 2142<br>2374<br>2730<br>2942<br>700D<br>1114<br>1969<br>2343 | 2182<br>2421<br>2777<br>2943M<br>706<br>1117<br>1980<br>2352 | 2189<br>2505<br>2787<br>2947<br>842<br>1119<br>2049<br>2367M | | size | .972<br>1377<br>2198<br>2552<br>2812<br>2949<br>533D<br>998d<br>1131<br>2123d<br>2481<br>3288<br>87D<br>3465 | 984<br>1385<br>2207<br>2634<br>2872<br>2965<br>636<br>1007<br>1136<br>2126<br>2580<br>3300<br>126 | 992<br>1413<br>2209<br>2644<br>2877<br>2982<br>647D<br>1015<br>1473<br>2169<br>2648<br>3369D<br>684 | 1071D<br>1752<br>2221<br>2694<br>2914<br>652M<br>1018<br>1501<br>2210<br>3007<br>3377 | 2025D<br>2303<br>2695<br>2918<br>656<br>1071D<br>1520<br>2297<br>3013<br>3383M | 2089<br>2333<br>2716<br>2920<br>659<br>1078<br>1521<br>2318<br>3014<br>3423M | 2103<br>2368M<br>2727<br>2925M<br>661<br>1105<br>1758<br>2325<br>3057<br>3424 | 2142<br>2374<br>2730<br>2942<br>700D<br>1114<br>1969<br>2343<br>3250 | 2182<br>2421<br>2777<br>2943M<br>706<br>1117<br>1980<br>2352<br>3251 | 2189<br>2505<br>2787<br>2947<br>842<br>1119<br>2049<br>2367M<br>3252 | | size | .972<br>1377<br>2198<br>2552<br>2812<br>2949<br>533D<br>998d<br>1131<br>2123d<br>2481<br>3288<br>87D<br>3465<br>960D | 984<br>1385<br>2207<br>2634<br>2872<br>2965<br>636<br>1007<br>1136<br>2126<br>2580<br>3300<br>126 | 992<br>1413<br>2209<br>2644<br>2877<br>2982<br>647D<br>1015<br>1473<br>2169<br>2648<br>3369D<br>684 | 1071D<br>1752<br>2221<br>2694<br>2914<br>652M<br>1018<br>1501<br>2210<br>3007<br>3377 | 2025D<br>2303<br>2695<br>2918<br>656<br>1071D<br>1520<br>2297<br>3013<br>3383M<br>688 | 2089<br>2333<br>2716<br>2920<br>659<br>1078<br>1521<br>2318<br>3014<br>3423M | 2103<br>2368M<br>2727<br>2925M<br>661<br>1105<br>1758<br>2325<br>3057<br>3424 | 2142<br>2374<br>2730<br>2942<br>700D<br>1114<br>1969<br>2343<br>3250 | 2182<br>2421<br>2777<br>2943M<br>706<br>1117<br>1980<br>2352<br>3251 | 2189<br>2505<br>2787<br>2947<br>842<br>1119<br>2049<br>2367M<br>3252 | | size<br>size_divider | .972<br>1377<br>2198<br>2552<br>2812<br>2949<br>533D<br>998d<br>1131<br>2123d<br>2481<br>3288<br>87D<br>3465<br>960D<br>100D | 984<br>1385<br>2207<br>2634<br>2872<br>2965<br>636<br>1007<br>1136<br>2126<br>2580<br>3300<br>126<br>969<br>147 | 992<br>1413<br>2209<br>2644<br>2877<br>2982<br>647D<br>1015<br>1473<br>2169<br>2648<br>3369D<br>684 | 1071D<br>1752<br>2221<br>2694<br>2914<br>652M<br>1018<br>1501<br>2210<br>3007<br>3377 | 2025D<br>2303<br>2695<br>2918<br>656<br>1071D<br>1520<br>2297<br>3013<br>3383M | 2089<br>2333<br>2716<br>2920<br>659<br>1078<br>1521<br>2318<br>3014<br>3423M | 2103<br>2368M<br>2727<br>2925M<br>661<br>1105<br>1758<br>2325<br>3057<br>3424 | 2142<br>2374<br>2730<br>2942<br>700D<br>1114<br>1969<br>2343<br>3250 | 2182<br>2421<br>2777<br>2943M<br>706<br>1117<br>1980<br>2352<br>3251 | 2189<br>2505<br>2787<br>2947<br>842<br>1119<br>2049<br>2367M<br>3252 | | size divider sort_require spaceclaimed spacecount | .972<br>1377<br>2198<br>2552<br>2812<br>2949<br>533D<br>998d<br>1131<br>2123d<br>2481<br>3288<br>87D<br>3465<br>960D<br>100D<br>569D | 984<br>1385<br>2207<br>2634<br>2872<br>2965<br>636<br>1007<br>1136<br>2126<br>2580<br>3300<br>126<br>969<br>147<br>696 | 992<br>1413<br>2209<br>2644<br>2877<br>2982<br>647D<br>1015<br>1473<br>2169<br>2648<br>3369D<br>684<br>973<br>722<br>3344 | 1071D<br>1752<br>2221<br>2694<br>2914<br>652M<br>1018<br>1501<br>2210<br>3007<br>3377<br>687 | 2025D<br>2303<br>2695<br>2918<br>656<br>1071D<br>1520<br>2297<br>3013<br>3383M<br>688 | 2089<br>2333<br>2716<br>2920<br>659<br>1078<br>1521<br>2318<br>3014<br>3423M | 2103<br>2368M<br>2727<br>2925M<br>661<br>1105<br>1758<br>2325<br>3057<br>3424 | 2142<br>2374<br>2730<br>2942<br>700D<br>1114<br>1969<br>2343<br>3250 | 2182<br>2421<br>2777<br>2943M<br>706<br>1117<br>1980<br>2352<br>3251 | 2189<br>2505<br>2787<br>2947<br>842<br>1119<br>2049<br>2367M<br>3252 | | size divider sort_require spaceclaimed spacecount spacefound | .972<br>1377<br>2198<br>2552<br>2812<br>2949<br>533D<br>998d<br>1131<br>2123d<br>2481<br>3288<br>87D<br>3465<br>960D<br>100D<br>569D<br>1216D | 984<br>1385<br>2207<br>2634<br>2872<br>2965<br>636<br>1007<br>1136<br>2126<br>2580<br>3300<br>126<br>969<br>147<br>696<br>1261M | 992<br>1413<br>2209<br>2644<br>2877<br>2982<br>647D<br>1015<br>1473<br>2169<br>2648<br>3369D<br>684<br>973<br>722<br>3344<br>1263 | 1071D<br>1752<br>2221<br>2694<br>2914<br>652M<br>1018<br>1501<br>2210<br>3007<br>3377<br>687 | 2025D<br>2303<br>2695<br>2918<br>656<br>1071D<br>1520<br>2297<br>3013<br>3383M<br>688 | 2089<br>2333<br>2716<br>2920<br>659<br>1078<br>1521<br>2318<br>3014<br>3423M | 2103<br>2368M<br>2727<br>2925M<br>661<br>1105<br>1758<br>2325<br>3057<br>3424 | 2142<br>2374<br>2730<br>2942<br>700D<br>1114<br>1969<br>2343<br>3250 | 2182<br>2421<br>2777<br>2943M<br>706<br>1117<br>1980<br>2352<br>3251 | 2189<br>2505<br>2787<br>2947<br>842<br>1119<br>2049<br>2367M<br>3252 | | size divider sort_require spaceclaimed spacecount | .972<br>1377<br>2198<br>2552<br>2812<br>2949<br>533D<br>998d<br>1131<br>2123d<br>2481<br>3288<br>87D<br>3465<br>960D<br>100D<br>569D<br>1216D<br>595D | 984<br>1385<br>2207<br>2634<br>2872<br>2965<br>636<br>1007<br>1136<br>2126<br>2580<br>3300<br>126<br>969<br>147<br>696<br>1261M<br>613 | 992<br>1413<br>2209<br>2644<br>2877<br>2982<br>647D<br>1015<br>1473<br>2169<br>2648<br>3369D<br>684<br>973<br>722<br>3344<br>1263<br>655 | 1071D<br>1752<br>2221<br>2694<br>2914<br>652M<br>1018<br>1501<br>2210<br>3007<br>3377<br>687 | 2025D<br>2303<br>2695<br>2918<br>656<br>1071D<br>1520<br>2297<br>3013<br>3383M<br>688<br>1291 | 2089<br>2333<br>2716<br>2920<br>659<br>1078<br>1521<br>2318<br>3014<br>3423M<br>689 | 2103<br>2368M<br>2727<br>2925M<br>661<br>1105<br>1758<br>2325<br>3057<br>3424 | 2142<br>2374<br>2730<br>2942<br>700D<br>1114<br>1969<br>2343<br>3250 | 2182<br>2421<br>2777<br>2943M<br>706<br>1117<br>1980<br>2352<br>3251 | 2189<br>2505<br>2787<br>2947<br>842<br>1119<br>2049<br>2367M<br>3252 | | size divider sort_require spaceclaimed spacecount spacedempty spaceq | .972<br>1377<br>2198<br>2552<br>2812<br>2949<br>533D<br>998d<br>1131<br>2123d<br>2481<br>3288<br>87D<br>3465<br>960D<br>100D<br>569D<br>1216D<br>595D<br>577D | 984<br>1385<br>2207<br>2634<br>2872<br>2965<br>636<br>1007<br>1136<br>2126<br>2580<br>3300<br>126<br>969<br>147<br>696<br>1261M<br>613<br>611 | 992<br>1413<br>2209<br>2644<br>2877<br>2982<br>647D<br>1015<br>1473<br>2169<br>2648<br>3369D<br>684<br>973<br>722<br>3344<br>1263<br>655<br>684 | 1071D<br>1752<br>2221<br>2694<br>2914<br>652M<br>1018<br>1501<br>2210<br>3007<br>3377<br>687<br>1066 | 2025D<br>2303<br>2695<br>2918<br>656<br>1071D<br>1520<br>2297<br>3013<br>3383M<br>688<br>1291<br>1295<br>714<br>725 | 2089<br>2333<br>2716<br>2920<br>659<br>1078<br>1521<br>2318<br>3014<br>3423M<br>689 | 2103<br>2368M<br>2727<br>2925M<br>661<br>1105<br>1758<br>2325<br>3057<br>3424<br>733 | 2142<br>2374<br>2730<br>2942<br>700D<br>1114<br>1969<br>2343<br>3250<br>735 | 2182<br>2421<br>2777<br>2943M<br>706<br>1117<br>1980<br>2352<br>3251<br>736 | 2189<br>2505<br>2787<br>2947<br>842<br>1119<br>2049<br>2367M<br>3252 | | size divider sort_require spaceclaimed spacecount spacedempty spaceq space_situat | .972<br>1377<br>2198<br>2552<br>2812<br>2949<br>533D<br>998d<br>1131<br>2123d<br>2481<br>3288<br>87D<br>3465<br>960D<br>100D<br>569D<br>1216D<br>595D<br>577D<br>606D | 984<br>1385<br>2207<br>2634<br>2872<br>2965<br>636<br>1007<br>1136<br>2126<br>2580<br>3300<br>126<br>969<br>147<br>696<br>1261M<br>613<br>611<br>633 | 992<br>1413<br>2209<br>2644<br>2877<br>2982<br>647D<br>1015<br>1473<br>2169<br>2648<br>3369D<br>684<br>973<br>722<br>3344<br>1263<br>655<br>684<br>636 | 1071D<br>1752<br>2221<br>2694<br>2914<br>652M<br>1018<br>1501<br>2210<br>3007<br>3377<br>687<br>1066 | 2025D<br>2303<br>2695<br>2918<br>656<br>1071D<br>1520<br>2297<br>3013<br>3383M<br>688<br>1291<br>1295<br>714<br>725<br>992 | 2089<br>2333<br>2716<br>2920<br>659<br>1078<br>1521<br>2318<br>3014<br>3423M<br>689 | 2103<br>2368M<br>2727<br>2925M<br>661<br>1105<br>1758<br>2325<br>3057<br>3424<br>733 | 2142<br>2374<br>2730<br>2942<br>700D<br>1114<br>1969<br>2343<br>3250<br>735 | 2182<br>2421<br>2777<br>2943M<br>706<br>1117<br>1980<br>2352<br>3251<br>736 | 2189<br>2505<br>2787<br>2947<br>842<br>1119<br>2049<br>2367M<br>3252<br>982 | | size divider sort_require spaceclaimed spacecount spacedempty spaceq | .972<br>1377<br>2198<br>2552<br>2812<br>2949<br>533D<br>998d<br>1131<br>2123d<br>2481<br>3288<br>87D<br>3465<br>960D<br>100D<br>569D<br>1216D<br>595D<br>577D<br>606D<br>618 | 984<br>1385<br>2207<br>2634<br>2872<br>2965<br>636<br>1007<br>1136<br>2126<br>2580<br>3300<br>126<br>969<br>147<br>696<br>1261M<br>613<br>611<br>633<br>896D | 992<br>1413<br>2209<br>2644<br>2877<br>2982<br>647D<br>1015<br>1473<br>2169<br>2648<br>3369D<br>684<br>973<br>722<br>3344<br>1263<br>655<br>684<br>636<br>906 | 1071D<br>1752<br>2221<br>2694<br>2914<br>652M<br>1018<br>1501<br>2210<br>3007<br>3377<br>687<br>1066 | 2025D<br>2303<br>2695<br>2918<br>656<br>1071D<br>1520<br>2297<br>3013<br>3383M<br>688<br>1291<br>1295<br>714<br>725 | 2089<br>2333<br>2716<br>2920<br>659<br>1078<br>1521<br>2318<br>3014<br>3423M<br>689 | 2103<br>2368M<br>2727<br>2925M<br>661<br>1105<br>1758<br>2325<br>3057<br>3424<br>733 | 2142<br>2374<br>2730<br>2942<br>700D<br>1114<br>1969<br>2343<br>3250<br>735 | 2182<br>2421<br>2777<br>2943M<br>706<br>1117<br>1980<br>2352<br>3251<br>736 | 2189<br>2505<br>2787<br>2947<br>842<br>1119<br>2049<br>2367M<br>3252 | | size divider sort_require spaceclaimed spacecount spacefound spaceqempty spaceq space_situat sq | .972<br>1377<br>2198<br>2552<br>2812<br>2949<br>533D<br>998d<br>1131<br>2123d<br>2481<br>3288<br>87D<br>3465<br>960D<br>100D<br>569D<br>1216D<br>595D<br>577D<br>606D<br>618 | 984<br>1385<br>2207<br>2634<br>2872<br>2965<br>636<br>1007<br>1136<br>2126<br>2580<br>3300<br>126<br>969<br>147<br>696<br>1261M<br>613<br>611<br>633<br>896D<br>3245 | 992<br>1413<br>2209<br>2644<br>2877<br>2982<br>647D<br>1015<br>1473<br>2169<br>2648<br>3369D<br>684<br>973<br>722<br>3344<br>1263<br>655<br>684<br>636<br>906<br>3413 | 1071D<br>1752<br>2221<br>2694<br>2914<br>652M<br>1018<br>1501<br>2210<br>3007<br>3377<br>687<br>1066 | 2025D<br>2303<br>2695<br>2918<br>656<br>1071D<br>1520<br>2297<br>3013<br>3383M<br>688<br>1291<br>1295<br>714<br>725<br>992 | 2089<br>2333<br>2716<br>2920<br>659<br>1078<br>1521<br>2318<br>3014<br>3423M<br>689 | 2103<br>2368M<br>2727<br>2925M<br>661<br>1105<br>1758<br>2325<br>3057<br>3424<br>733 | 2142<br>2374<br>2730<br>2942<br>700D<br>1114<br>1969<br>2343<br>3250<br>735 | 2182<br>2421<br>2777<br>2943M<br>706<br>1117<br>1980<br>2352<br>3251<br>736 | 2189<br>2505<br>2787<br>2947<br>842<br>1119<br>2049<br>2367M<br>3252<br>982 | | size divider sort_require spaceclaimed spacecount spacefound spaceqempty spaceq space_situat sq | .972<br>1377<br>2198<br>2552<br>2812<br>2949<br>533D<br>998d<br>1131<br>2123d<br>2481<br>3288<br>87D<br>3465<br>960D<br>100D<br>569D<br>1216D<br>595D<br>577D<br>606D<br>618<br>3243<br>471 | 984<br>1385<br>2207<br>2634<br>2872<br>2965<br>636<br>1007<br>1136<br>2126<br>2580<br>3300<br>126<br>969<br>147<br>696<br>1261M<br>613<br>611<br>633<br>896D<br>3245<br>485 | 992<br>1413<br>2209<br>2644<br>2877<br>2982<br>647D<br>1015<br>1473<br>2169<br>2648<br>3369D<br>684<br>973<br>722<br>3344<br>1263<br>655<br>684<br>636<br>906<br>3413<br>487 | 1071D<br>1752<br>2221<br>2694<br>2914<br>652M<br>1018<br>1501<br>2210<br>3007<br>3377<br>687<br>1066<br>1291<br>682<br>715<br>985<br>1836 | 2025D<br>2303<br>2695<br>2918<br>656<br>1071D<br>1520<br>2297<br>3013<br>3383M<br>688<br>1291<br>1295<br>714<br>725<br>992<br>1838 | 2089<br>2333<br>2716<br>2920<br>659<br>1078<br>1521<br>2318<br>3014<br>3423M<br>689 | 2103<br>2368M<br>2727<br>2925M<br>661<br>1105<br>1758<br>2325<br>3057<br>3424<br>733 | 2142<br>2374<br>2730<br>2942<br>700D<br>1114<br>1969<br>2343<br>3250<br>735 | 2182<br>2421<br>2777<br>2943M<br>706<br>1117<br>1980<br>2352<br>3251<br>736 | 2189<br>2505<br>2787<br>2947<br>842<br>1119<br>2049<br>2367M<br>3252<br>982 | | size divider sort_require spaceclaimed spacecount spacefound spaceqempty spaceq space situat sq sqrt sr | .972<br>1377<br>2198<br>2552<br>2812<br>2949<br>533D<br>998d<br>1131<br>2123d<br>2481<br>3288<br>87D<br>3465<br>960D<br>100D<br>569D<br>1216D<br>595D<br>577D<br>606D<br>618<br>3243<br>471<br>703D | 984<br>1385<br>2207<br>2634<br>2872<br>2965<br>636<br>1007<br>1136<br>2126<br>2580<br>3300<br>126<br>969<br>147<br>696<br>1261M<br>613<br>611<br>633<br>896D<br>3245<br>485<br>715 | 992<br>1413<br>2209<br>2644<br>2877<br>2982<br>647D<br>1015<br>1473<br>2169<br>2648<br>3369D<br>684<br>973<br>722<br>3344<br>1263<br>655<br>684<br>636<br>906<br>3413<br>487<br>717 | 1071D<br>1752<br>2221<br>2694<br>2914<br>652M<br>1018<br>1501<br>2210<br>3007<br>3377<br>687<br>1066<br>1291<br>682<br>715<br>985<br>1836 | 2025D<br>2303<br>2695<br>2918<br>656<br>1071D<br>1520<br>2297<br>3013<br>3383M<br>688<br>1291<br>1295<br>714<br>725<br>992<br>1838 | 2089<br>2333<br>2716<br>2920<br>659<br>1078<br>1521<br>2318<br>3014<br>3423M<br>689 | 2103<br>2368M<br>2727<br>2925M<br>661<br>1105<br>1758<br>2325<br>3057<br>3424<br>733 | 2142<br>2374<br>2730<br>2942<br>700D<br>1114<br>1969<br>2343<br>3250<br>735 | 2182<br>2421<br>2777<br>2943M<br>706<br>1117<br>1980<br>2352<br>3251<br>736 | 2189<br>2505<br>2787<br>2947<br>842<br>1119<br>2049<br>2367M<br>3252<br>982 | | size divider sort_require spaceclaimed spacecount spacefound spaceqempty spaceq space situat sq sqrt sr | .972<br>1377<br>2198<br>2552<br>2812<br>2949<br>533D<br>998d<br>1131<br>2123d<br>2481<br>3288<br>87D<br>3465<br>960D<br>100D<br>569D<br>1216D<br>577D<br>606D<br>618<br>3243<br>471<br>703D<br>783D | 984<br>1385<br>2207<br>2634<br>2872<br>2965<br>636<br>1007<br>1136<br>2126<br>2580<br>3300<br>126<br>969<br>147<br>696<br>1261M<br>613<br>611<br>633<br>896D<br>3245<br>485<br>715<br>795 | 992<br>1413<br>2209<br>2644<br>2877<br>2982<br>647D<br>1015<br>1473<br>2169<br>2648<br>3369D<br>684<br>973<br>722<br>3344<br>1263<br>655<br>684<br>636<br>906<br>3413<br>487<br>717<br>799 | 1071D<br>1752<br>2221<br>2694<br>2914<br>652M<br>1018<br>1501<br>2210<br>3007<br>3377<br>687<br>1066<br>1291<br>682<br>715<br>985<br>1836 | 2025D<br>2303<br>2695<br>2918<br>656<br>1071D<br>1520<br>2297<br>3013<br>3383M<br>688<br>1291<br>1295<br>714<br>725<br>992<br>1838 | 2089<br>2333<br>2716<br>2920<br>659<br>1078<br>1521<br>2318<br>3014<br>3423M<br>689<br>741<br>1897<br>3155D | 2103<br>2368M<br>2727<br>2925M<br>661<br>1105<br>1758<br>2325<br>3057<br>3424<br>733<br>1485<br>1905<br>3177 | 2142<br>2374<br>2730<br>2942<br>700D<br>1114<br>1969<br>2343<br>3250<br>735 | 2182<br>2421<br>2777<br>2943M<br>706<br>1117<br>1980<br>2352<br>3251<br>736 | 2189<br>2505<br>2787<br>2947<br>842<br>1119<br>2049<br>2367M<br>3252<br>982 | | size divider sort_require spaceclaimed spacecount spacefound spaceqempty spaceq space situat sq sqrt sr | .972<br>1377<br>2198<br>2552<br>2812<br>2949<br>533D<br>998d<br>1131<br>2123d<br>2481<br>3288<br>87D<br>3465<br>960D<br>100D<br>569D<br>1216D<br>595D<br>577D<br>606D<br>618<br>3243<br>471<br>703D<br>783D | 984<br>1385<br>2207<br>2634<br>2872<br>2965<br>636<br>1007<br>1136<br>2126<br>2580<br>3300<br>126<br>969<br>147<br>696<br>1261M<br>613<br>611<br>633<br>896D<br>3245<br>485<br>715<br>795<br>2252D | 992<br>1413<br>2209<br>2644<br>2877<br>2982<br>647D<br>1015<br>1473<br>2169<br>2648<br>3369D<br>684<br>973<br>722<br>3344<br>1263<br>655<br>684<br>636<br>906<br>3413<br>487<br>717<br>799<br>2259 | 1071D<br>1752<br>2221<br>2694<br>2914<br>652M<br>1018<br>1501<br>2210<br>3007<br>3377<br>687<br>1066<br>1291<br>682<br>715<br>985<br>1836 | 2025D<br>2303<br>2695<br>2918<br>656<br>1071D<br>1520<br>2297<br>3013<br>3383M<br>688<br>1291<br>1295<br>714<br>725<br>992<br>1838 | 2089<br>2333<br>2716<br>2920<br>659<br>1078<br>1521<br>2318<br>3014<br>3423M<br>689 | 2103<br>2368M<br>2727<br>2925M<br>661<br>1105<br>1758<br>2325<br>3057<br>3424<br>733 | 2142<br>2374<br>2730<br>2942<br>700D<br>1114<br>1969<br>2343<br>3250<br>735 | 2182<br>2421<br>2777<br>2943M<br>706<br>1117<br>1980<br>2352<br>3251<br>736 | 2189<br>2505<br>2787<br>2947<br>842<br>1119<br>2049<br>2367M<br>3252<br>982 | | size divider sort_require spaceclaimed spacecount spacefound spaceqempty spaceq space_situat sq sqrt sr st st | .972<br>1377<br>2198<br>2552<br>2812<br>2949<br>533D<br>998d<br>1131<br>2123d<br>2481<br>3288<br>87D<br>3465<br>960D<br>100D<br>569D<br>1216D<br>595D<br>577D<br>606D<br>618<br>3243<br>471<br>703D<br>783D<br>1861<br>2278m | 984<br>1385<br>2207<br>2634<br>2872<br>2965<br>636<br>1007<br>1136<br>2126<br>2580<br>3300<br>126<br>969<br>147<br>696<br>1261M<br>613<br>611<br>633<br>896D<br>3245<br>485<br>715<br>795<br>2252D<br>2279 | 992<br>1413<br>2209<br>2644<br>2877<br>2982<br>647D<br>1015<br>1473<br>2169<br>2648<br>3369D<br>684<br>973<br>722<br>3344<br>1263<br>655<br>684<br>636<br>906<br>3413<br>487<br>717<br>799<br>2259<br>2449 | 1071D<br>1752<br>2221<br>2694<br>2914<br>652M<br>1018<br>1501<br>2210<br>3007<br>3377<br>687<br>1066<br>1291<br>682<br>715<br>985<br>1836 | 2025D<br>2303<br>2695<br>2918<br>656<br>1071D<br>1520<br>2297<br>3013<br>3383M<br>688<br>1291<br>1295<br>714<br>725<br>992<br>1838 | 2089<br>2333<br>2716<br>2920<br>659<br>1078<br>1521<br>2318<br>3014<br>3423M<br>689<br>741<br>1897<br>3155D | 2103<br>2368M<br>2727<br>2925M<br>661<br>1105<br>1758<br>2325<br>3057<br>3424<br>733<br>1485<br>1905<br>3177 | 2142<br>2374<br>2730<br>2942<br>700D<br>1114<br>1969<br>2343<br>3250<br>735 | 2182<br>2421<br>2777<br>2943M<br>706<br>1117<br>1980<br>2352<br>3251<br>736 | 2189<br>2505<br>2787<br>2947<br>842<br>1119<br>2049<br>2367M<br>3252<br>982 | | size divider sort_require spaceclaimed spacecount spacefound spaceq empty spaceq space situat sq sqrt sr st stackp | .972<br>1377<br>2198<br>2552<br>2812<br>2949<br>533D<br>998d<br>1131<br>2123d<br>2481<br>3288<br>87D<br>3465<br>960D<br>100D<br>569D<br>1216D<br>595D<br>577D<br>606D<br>618<br>3243<br>471<br>703D<br>783D<br>1861<br>2278m<br>78D | 984<br>1385<br>2207<br>2634<br>2872<br>2965<br>636<br>1007<br>1136<br>2126<br>2580<br>3300<br>126<br>969<br>147<br>696<br>1261M<br>613<br>896D<br>3245<br>485<br>715<br>795<br>2252D<br>2279<br>124 | 992<br>1413<br>2209<br>2644<br>2877<br>2982<br>647D<br>1015<br>1473<br>2169<br>2648<br>3369D<br>684<br>973<br>722<br>3344<br>1263<br>655<br>684<br>636<br>906<br>3413<br>487<br>717<br>799<br>2259<br>2449<br>2250 | 1071D<br>1752<br>2221<br>2694<br>2914<br>652M<br>1018<br>1501<br>2210<br>3007<br>3377<br>687<br>1066<br>1291<br>682<br>715<br>985<br>1836 | 2025D<br>2303<br>2695<br>2918<br>656<br>1071D<br>1520<br>2297<br>3013<br>3383M<br>688<br>1291<br>1295<br>714<br>725<br>992<br>1838<br>722<br>812<br>2265M<br>2300 | 2089<br>2333<br>2716<br>2920<br>659<br>1078<br>1521<br>2318<br>3014<br>3423M<br>689<br>741<br>1897<br>3155D | 2103<br>2368M<br>2727<br>2925M<br>661<br>1105<br>1758<br>2325<br>3057<br>3424<br>733<br>1485<br>1905<br>3177<br>725<br>838<br>2268 | 2142<br>2374<br>2730<br>2942<br>700D<br>1114<br>1969<br>2343<br>3250<br>735<br>1508<br>3376<br>3216<br>735M<br>2269 | 2182<br>2421<br>2777<br>2943M<br>706<br>1117<br>1980<br>2352<br>3251<br>736<br>1894<br>3228<br>741 | 2189<br>2505<br>2787<br>2947<br>842<br>1119<br>2049<br>2367M<br>3252<br>982 | | size divider sort_require spaceclaimed spacecount spacefound spaceqempty spaceq space_situat sq sqrt sr st st | .972<br>1377<br>2198<br>2552<br>2812<br>2949<br>533D<br>998d<br>1131<br>2123d<br>2481<br>3288<br>87D<br>3465<br>960D<br>100D<br>569D<br>1216D<br>595D<br>577D<br>606D<br>618<br>3243<br>471<br>703D<br>783D<br>1861<br>2278m<br>78D<br>722 | 984<br>1385<br>2207<br>2634<br>2872<br>2965<br>636<br>1007<br>1136<br>2126<br>2580<br>3300<br>126<br>969<br>147<br>696<br>1261M<br>613<br>611<br>633<br>896D<br>3245<br>485<br>715<br>795<br>2252D<br>2279<br>124<br>873 | 992<br>1413<br>2209<br>2644<br>2877<br>2982<br>647D<br>1015<br>1473<br>2169<br>2648<br>3369D<br>684<br>973<br>722<br>3344<br>1263<br>655<br>684<br>636<br>906<br>3413<br>487<br>717<br>799<br>2259<br>2449<br>2250<br>1041 | 1071D<br>1752<br>2221<br>2694<br>2914<br>652M<br>1018<br>1501<br>2210<br>3007<br>3377<br>687<br>1066<br>1291<br>682<br>715<br>985<br>1836 | 2025D<br>2303<br>2695<br>2918<br>656<br>1071D<br>1520<br>2297<br>3013<br>3383M<br>688<br>1291<br>1295<br>714<br>725<br>992<br>1838<br>722<br>812<br>2265H<br>2300<br>1058 | 2089<br>2333<br>2716<br>2920<br>659<br>1078<br>1521<br>2318<br>3014<br>3423M<br>689<br>741<br>1897<br>3155D<br>723<br>815<br>2266<br>2449<br>1066 | 2103<br>2368M<br>2727<br>2925M<br>661<br>1105<br>1758<br>2325<br>3057<br>3424<br>733<br>1485<br>1905<br>3177<br>725<br>838<br>2268 | 2142<br>2374<br>2730<br>2942<br>700D<br>1114<br>1969<br>2343<br>3250<br>735<br><br>1508<br>3376<br>3216<br>735M<br>2269 | 2182<br>2421<br>2777<br>2943M<br>706<br>1117<br>1980<br>2352<br>3251<br>736<br>1894<br>3228<br>741<br>2271 | 2189<br>2505<br>2787<br>2947<br>842<br>1119<br>2049<br>2367M<br>3252<br>982 | | size divider sort_require spaceclaimed spacecount spacefound spaceqempty spaceq space situat sq sqrt sr st stackp stack_depth stage | .972<br>1377<br>2198<br>2552<br>2812<br>2949<br>533D<br>998d<br>1131<br>2123d<br>2481<br>3288<br>87D<br>3465<br>960D<br>100D<br>569D<br>1216D<br>595D<br>577D<br>606D<br>618<br>3243<br>471<br>703D<br>783D<br>1861<br>2278m<br>78D<br>722<br>1201 | 984<br>1385<br>2207<br>2634<br>2872<br>2965<br>636<br>1007<br>1136<br>2126<br>2580<br>3300<br>126<br>969<br>147<br>696<br>1261M<br>613<br>611<br>633<br>896D<br>3245<br>485<br>715<br>795<br>2252D<br>2279<br>124<br>873<br>1203 | 992<br>1413<br>2209<br>2644<br>2877<br>2982<br>647D<br>1015<br>1473<br>2169<br>2648<br>3369D<br>684<br>973<br>722<br>3344<br>1263<br>655<br>684<br>636<br>906<br>3413<br>487<br>717<br>799<br>2259<br>2449<br>2250<br>1041<br>1291 | 1071D<br>1752<br>2221<br>2694<br>2914<br>652M<br>1018<br>1501<br>2210<br>3007<br>3377<br>687<br>1066<br>1291<br>682<br>715<br>985<br>1836 | 2025D<br>2303<br>2695<br>2918<br>656<br>1071D<br>1520<br>2297<br>3013<br>3383M<br>688<br>1291<br>1295<br>714<br>725<br>992<br>1838<br>722<br>812<br>2265M<br>2300<br>1058<br>1445 | 2089<br>2333<br>2716<br>2920<br>659<br>1078<br>1521<br>2318<br>3014<br>3423M<br>689<br>741<br>1897<br>3155D<br>723<br>815<br>2266<br>2449<br>1066<br>1712 | 2103<br>2368M<br>2727<br>2925M<br>661<br>1105<br>1758<br>2325<br>3057<br>3424<br>733<br>1485<br>1905<br>3177<br>725<br>838<br>2268 | 2142<br>2374<br>2730<br>2942<br>700D<br>1114<br>1969<br>2343<br>3250<br>735<br>1508<br>3376<br>3216<br>735M<br>2269 | 2182<br>2421<br>2777<br>2943M<br>706<br>1117<br>1980<br>2352<br>3251<br>736<br>1894<br>3228<br>741 | 2189<br>2505<br>2787<br>2947<br>842<br>1119<br>2049<br>2367M<br>3252<br>982 | | size divider sort_require spaceclaimed spacecount spacefound spaceqempty spaceq situat sq sqrt sr st stackp stack_depth stage start | .972<br>1377<br>2198<br>2552<br>2812<br>2949<br>533D<br>998d<br>1131<br>2123d<br>2481<br>3288<br>87D<br>3465<br>960D<br>100D<br>569D<br>1216D<br>595D<br>577D<br>606D<br>618<br>3243<br>471<br>703D<br>783D<br>1861<br>2278m<br>78D<br>722<br>1201<br>343D | 984<br>1385<br>2207<br>2634<br>2872<br>2965<br>636<br>1007<br>1136<br>2126<br>2580<br>3300<br>126<br>969<br>147<br>696<br>1261M<br>613<br>611<br>633<br>896D<br>3245<br>485<br>715<br>795<br>2252D<br>2279<br>124<br>873<br>1203<br>1578 | 992<br>1413<br>2209<br>2644<br>2877<br>2982<br>647D<br>1015<br>1473<br>2169<br>2648<br>3369D<br>684<br>973<br>722<br>3344<br>1263<br>655<br>684<br>636<br>906<br>3413<br>487<br>717<br>799<br>2259<br>2449<br>2250<br>1041<br>1291<br>1910 | 1071D<br>1752<br>2221<br>2694<br>2914<br>652M<br>1018<br>1501<br>2210<br>3007<br>3377<br>687<br>1066<br>1291<br>682<br>715<br>985<br>1836<br>720<br>803<br>2263<br>2966<br>2263<br>1047M<br>1414<br>3062 | 2025D<br>2303<br>2695<br>2918<br>656<br>1071D<br>1520<br>2297<br>3013<br>3383M<br>688<br>1291<br>1295<br>714<br>725<br>992<br>1838<br>722<br>812<br>2265M<br>2300<br>1058<br>1445<br>3075 | 2089<br>2333<br>2716<br>2920<br>659<br>1078<br>1521<br>2318<br>3014<br>3423M<br>689<br>741<br>1897<br>3155D<br>723<br>815<br>2266<br>2449<br>1066<br>1712<br>3296 | 2103<br>2368M<br>2727<br>2925M<br>661<br>1105<br>1758<br>2325<br>3057<br>3424<br>733<br>1485<br>1905<br>3177<br>725<br>838<br>2268 | 2142<br>2374<br>2730<br>2942<br>700D<br>1114<br>1969<br>2343<br>3250<br>735<br><br>1508<br>3376<br>3216<br>735M<br>2269 | 2182<br>2421<br>2777<br>2943M<br>706<br>1117<br>1980<br>2352<br>3251<br>736<br>1894<br>3228<br>741<br>2271 | 2189<br>2505<br>2787<br>2947<br>842<br>1119<br>2049<br>2367M<br>3252<br>982<br>3233 | | size divider sort_require spaceclaimed spacecount spacefound spaceqempty spaceq space situat sq sqrt sr st stackp stack_depth stage | .972<br>1377<br>2198<br>2552<br>2812<br>2949<br>533D<br>998d<br>1131<br>2123d<br>2481<br>3288<br>87D<br>3465<br>960D<br>100D<br>569D<br>1216D<br>595D<br>577D<br>606D<br>618<br>3243<br>471<br>703D<br>783D<br>1861<br>2278m<br>78D<br>722<br>1201<br>343D<br>340D | 984<br>1385<br>2207<br>2634<br>2872<br>2965<br>636<br>1007<br>1136<br>2126<br>2580<br>3300<br>126<br>969<br>147<br>696<br>1261M<br>613<br>611<br>633<br>896D<br>3245<br>485<br>715<br>795<br>2252D<br>2279<br>124<br>873<br>1203 | 992<br>1413<br>2209<br>2644<br>2877<br>2982<br>647D<br>1015<br>1473<br>2169<br>2648<br>3369D<br>684<br>973<br>722<br>3344<br>1263<br>655<br>684<br>636<br>906<br>3413<br>487<br>717<br>799<br>2259<br>2449<br>2250<br>1041<br>1291 | 1071D<br>1752<br>2221<br>2694<br>2914<br>652M<br>1018<br>1501<br>2210<br>3007<br>3377<br>687<br>1066<br>1291<br>682<br>715<br>985<br>1836 | 2025D<br>2303<br>2695<br>2918<br>656<br>1071D<br>1520<br>2297<br>3013<br>3383M<br>688<br>1291<br>1295<br>714<br>725<br>992<br>1838<br>722<br>812<br>2265M<br>2300<br>1058<br>1445 | 2089<br>2333<br>2716<br>2920<br>659<br>1078<br>1521<br>2318<br>3014<br>3423M<br>689<br>741<br>1897<br>3155D<br>723<br>815<br>2266<br>2449<br>1066<br>1712 | 2103<br>2368M<br>2727<br>2925M<br>661<br>1105<br>1758<br>2325<br>3057<br>3424<br>733<br>1485<br>1905<br>3177<br>725<br>838<br>2268 | 2142<br>2374<br>2730<br>2942<br>700D<br>1114<br>1969<br>2343<br>3250<br>735<br><br>1508<br>3376<br>3216<br>735M<br>2269 | 2182<br>2421<br>2777<br>2943M<br>706<br>1117<br>1980<br>2352<br>3251<br>736<br>1894<br>3228<br>741<br>2271 | 2189<br>2505<br>2787<br>2947<br>842<br>1119<br>2049<br>2367M<br>3252<br>982 | | size divider sort_require spaceclaimed spacecount spacefound spaceqempty spaceq situat sq sqrt sr st stackp stack_depth stage start | .972<br>1377<br>2198<br>2552<br>2812<br>2949<br>533D<br>998d<br>1131<br>2123d<br>2481<br>3288<br>87D<br>3465<br>960D<br>100D<br>569D<br>1216D<br>595D<br>577D<br>606D<br>618<br>3243<br>471<br>703D<br>783D<br>1861<br>2278m<br>78D<br>722<br>1201<br>343D | 984<br>1385<br>2207<br>2634<br>2872<br>2965<br>636<br>1007<br>1136<br>2126<br>2580<br>3300<br>126<br>969<br>147<br>696<br>1261M<br>613<br>611<br>633<br>896D<br>3245<br>485<br>715<br>795<br>2252D<br>2279<br>124<br>873<br>1203<br>1578 | 992 1413 2209 2644 2877 2982 647D 1015 1473 2169 2648 3369D 684 973 722 3344 1263 655 684 636 906 3413 487 717 799 2259 2449 2250 1041 1291 1910 | 1071D<br>1752<br>2221<br>2694<br>2914<br>652M<br>1018<br>1501<br>2210<br>3007<br>3377<br>687<br>1066<br>1291<br>682<br>715<br>985<br>1836<br>720<br>803<br>2263<br>2966<br>2263<br>1047M<br>1414<br>3062 | 2025D<br>2303<br>2695<br>2918<br>656<br>1071D<br>1520<br>2297<br>3013<br>3383M<br>688<br>1291<br>1295<br>714<br>725<br>992<br>1838<br>722<br>812<br>2265M<br>2300<br>1058<br>1445<br>3075 | 2089<br>2333<br>2716<br>2920<br>659<br>1078<br>1521<br>2318<br>3014<br>3423M<br>689<br>741<br>1897<br>3155D<br>723<br>815<br>2266<br>2449<br>1066<br>1712<br>3296 | 2103<br>2368M<br>2727<br>2925M<br>661<br>1105<br>1758<br>2325<br>3057<br>3424<br>733<br>1485<br>1905<br>3177<br>725<br>838<br>2268 | 2142<br>2374<br>2730<br>2942<br>700D<br>1114<br>1969<br>2343<br>3250<br>735<br><br>1508<br>3376<br>3216<br>735M<br>2269 | 2182<br>2421<br>2777<br>2943M<br>706<br>1117<br>1980<br>2352<br>3251<br>736<br>1894<br>3228<br>741<br>2271 | 2189<br>2505<br>2787<br>2947<br>842<br>1119<br>2049<br>2367M<br>3252<br>982<br>3233 | | | 506 | 514 | 515 | 520 | | | | | | | |--------------------|----------------|----------------|--------------|--------------|-------|-------|--------|-------|-------|-------| | statistic li | 292 | 294D | 498 | 515 | 3324 | 3441 | | | | | | status | 550D | 553 | 828 | 839 | 1116 | 1118H | 1129 | 1134 | 1357 | 1370 | | | 1372 | 1383 | 1392 | 2035 | 2084 | 2140 | 2299 | 2342 | 2351 | 2371M | | • | 2374m | 2378 | 2551 | 2573 | 2627 | 2629 | 2634 | 2643 | 2752 | | | stepl | 1598 | 2064D | 2413D | 2497D | 2535D | 2594D | 2734D | 2894D | | | | step2 | 1599 | 2065D | 2428D | 2512D | 2548D | 26080 | 27470 | 2900D | | | | step3 | 1600 | 2065D | 2441D | 2570D | 2617D | 27910 | 2934D | | | | | step4 | 1601 | 2065D | 2462D | 2797D | 2957D | | | | | | | step5 | 1602 | 2065D | 2473D | 1010 | 2061 | 2077 | 2202 | | | | | stop | 350D | 355 | 1583 | 1912 | 3064 | 3077 | 3283 | | | | | stpl | 1593 | 1598D | | | | | | | | | | stp2 | 1593 | 1599D | | | | | | | | | | stp3 | 1593 | 1600D<br>1601D | | | | | | | | | | stp4 | 1593<br>1593 | 1601b | | | | | | | | | | stp5<br>string | 202D | 209 | 210 | 211 | | | | | | | | sub | 211 | 2044 | 2045 | 2134 | 2419 | 2420 | 2421 | 2503 | 2504 | 2505 | | 840 | 2541 | -0 | 20.5 | | | | | • | | •- | | suc | 225 | 274 | 280 | 498 | 502 | 506 | 509 | 515 | 518 | 520 | | 546 | 523 | 1772 | 1779 | 1784 | 1838M | 1871 | 1873 | 2192 | 2693 | 2695 | | | 2696 | 2700m | 2701 | 2703 | 2712 | 2727 | 2730 | 2756 | 2757 | 2920 | | | 2950 | 2963 | 3171 | 3173 | 3186 | 3199 | 3243 | 3245 | 3282 | 3390 | | | 3394 | 3401 | 3405. | | | | | • | | | | success | 647Đ | 667 | 673 | | | | | | | | | supern | 83D | 128 | 2385 | 2907 | | | | • | | | | supervisorf | 2649 | 2652D | | • | | | | | | | | suspend | 2181D | | | | | | | | | | | switch_conte | 884 | 1528D | 3023 | 3066 | 3132 | | | | | | | sx | 441D | 446M | 454 · | 466M | 46811 | 469 | 470 | 473 | 476 | | | sx2 | 441D | 447M | 454 | 467M | 468 | 470 | | | | | | sxy | 441D | 448M | 454 | 467M | 469 | 470 | 471 | 473 | 477 | | | sy | 441D | 446M | 454 | 466M | 469 | 470 | 471 | 473M | 477 | | | sy2 | 441D | 447M | 454 | 467M | 471 | 473 | | | | | | sysout | 190 | 2/05 | | | | | | | | | | system_initi | 3321D | 3495 | 020 | 3414 | | | | | | | | s_channel | 601D | 616<br>616 | 938<br>1829 | 1832 | 2994D | 3007 | 3022 | | | | | s_channelc | 601 | 194 | 208D | 209 | 210 | 211 | 213 | 230D | 231 | 232M | | t | 187D<br>233 | 368d | 370 | 371 | 373 | 428D | 430 | 2132D | 2133 | 2134 | | | 2135 | 2417d | 2418 | 2419 | 2420 | 2421 | 2422 | 2501D | 2502 | 2503 | | | 2504 | 2505 | 2506 | 2539D | 2540 | 2541 | 2542 | | •- | | | thinking con | 3099D | 3371 | 3499 | 3502 | | | | | | | | thinktime | 3043D | 3044 | 3063 | | | | | | | | | think timer | 3041D | 3047 | 3062 | 3064 | | | | | | | | tied | 1145 | 1218D | 1231M | 1236 | 1263 | 1295 | 1297 . | 1313 | 2069D | 2221 | | time | · 184 | 347 | 353 | 355 | 361 | 370 | 389 | 392 | 399 | 405 | | | 406m | 756 | 1487 | 1577 | 1585 | 1586 | 3072 | 3079 | 3125 | | | timer | 333D | 603 | 621 | 2282 | 2296 | 3041 | 3047 | 3048 | 3276 | 3295 | | timeslice | 67D | 111 | 1425 | 1684 | 1697 | 2295 | 3482 | | | | | time average | 380D | 605 | 622 | | | | | | | | | total | 340D | 353M | 360 | 370 | 376 | 383D | 389M | 397 | 406 | 416D | | | 418 | 424 | 430M | 3507M | 3510 | | | | | | | total_entrie | 228D | 233 | 268 | 1897 | 1905 | | | | | | | total_respon | 561D | 3048 | 3327 | 3507 | 11/04 | 10/0 | 1056 | 1270 | 1318 | 2018D | | total_size | 1102 | 1119M | 1124M | 1136M | 1140M | 1240 | 1256 | 1270 | 1310 | 20100 | | trans . | 82D | 119 | 1118 | 1134 | 1370 | 1392 | 2342 | | | | | transfer | 3192 | 3205 | 3279D | 3316 | | | | | | | | transfers | 3277D | 3294 | 3299 | 2701 | 2706 | 2821 | 2845 | | | | | transfer_in_ | 2674D<br>2685D | 2758 | 2762<br>2807 | 2781<br>2808 | 2786 | 2021 | 2047 | | | | | trans_seg | | 2696M | | 1653 | 1676 | | | | | | | ts_clock | 589D | 620 | 1642 | 1000 | 1070 | | _ | | | | | typel | 2395 | 2407D<br>2485D | 2586 | | | | | | | | | typelf | 2482<br>2397 | 2493D<br>2493D | 2300 | | | | | | | | | type2 | 2519 | 2522D | | | | | | | | | | type2f<br>t length | 2319<br>88D | 127 | 782 | 783 | 787 | 799 | 815 | 3422 | | ٠, | | | 2201D | 2209 | 2227D | 2425 | 2431 | 2448 | 2450 | 2509 | 2545 | 2556 | | u | 2601 | 2602 | 2620 | 2627 | 2657 | 2661D | 2873 | 2904 | 2906 | 2908 | | | 3035d | 3044 | 3050 | 3275D | 3285M | 3287 | 3291 | | | | | ul | 2382D | 2383 | 2389 | 2401 | | - | | | | | | uniform | 2904 | 3287 | • | - | | | | | | | | uniquenumber | 2242D | 2246 | 2333 | | | | | | | | | unique | 2241D | 224411 | 2245 | 2246 | | | | | | | | update | 1733 | 1736 | 1740 | 1763 | 1764 | 1952D | | | | | | usage | 560D | 2296 | 3328 | 3507 | 3510 | | | | | | | userid | 30350 | 3046 | 3050 | 3069 | 3089 | | | | | | | userp | 97D | 161M | 162M | 2601 | | | | | | | | usert | 97D | 163พ | 16411 | 2601 | | | | | | | | user_supervi | 2385 | 2589D | | | | | | | | | | | | | | | | | | | | | | val. | 384D | 389 | 390 | 391M | 398 | 406 | | | | | |--------------|--------|-------|-------|--------|-------|-------|-------|--------|--------|-------| | valid | 1000 ~ | 148 | 873 | 1041 | 1414 | 1712 | 2194 | 2215 | | | | validated | 1034D | 1041 | 1640 | | | | | | | | | virtual proc | 1857 | 1859 | 1985 | 2206 | 2209 | 2227D | 2301 | 2303 | 2329 | 2445 | | | 2671 | 2889 | 3039 | 3050 | 3404 | | | | | 2175 | | w | 62711 | 629 | 630 | 632 | 633 | 636 | 1735 | 1736 | 1739 | 1740 | | | 1762 | 1763 | 2300 | 2301 | 2302 | 2303 | 2869 | 3237 | 3358D | 3450 | | | 3479 | 3480 | 3490 | | _ | | | | | 5.50 | | wait for d | 100D | 144 | 1047 | 1093 | 1195 | | | | | | | wait for sig | 2197D | 2854 | 2974 | | | | | | | | | warning_mess | 2686D | 2824 | 2826 | 2849 | | | | | | | | wfreeq | 2679D | 2697 | 2701 | 2703 | 2754 | 2756 | 2757 | - 2862 | 2870 | 3305 | | work | 759 | 1107 | 1249 | 1416 | 1467 | 1484 | 1508 | 1944D | 1955 | 3398 | | | 3401 | • | | | | | _ | | | 0070 | | wq | 2679D | 2693 | 2695 | 2696 | 2703 | 2757 | 2816 | 2841 | 2861 | | | wqh | 2681D | 2697 | 2700M | 2767 | 2830 | 2863 | | | | | | wq1 | 2681D | 2697 | 2700 | 2766 | 2830 | 2864 | | | • | | | x | 443D | 446 | 447M | 448 | 1543D | 1571 | 1573 | 1577 | 1578 | 1580 | | | 1583 | 1584 | 1585M | 1586 | 1595# | 1597 | 1598M | 1599M | 1600พ | 1601M | | | 1602m | 2072d | 2076M | 2079D | 2081 | 2089 | 2091 | 2095D | 2101 | 2103 | | | 2104 | 2111d | 2116 | 2117 | 2118 | 2123D | 2126 | 2413D | 2419 | 2421 | | | 2424 | 2425m | 2428D | 2431 | 2433 | 2434M | 2435M | 243711 | 2441D | 2447 | | | 2456 | 2458 | 2459 | 2462D | 2466 | 2470 | 2473D | 2476M | 2477M | 2497D | | | 2503 | 2505 | 2508 | 2509M | 2512D | 2514 | 2535D | 2541 | 2544 | 2545M | | | 2548d | 2551 | 2552M | 2554 | 2556M | 2559M | 2560 | 2561M | 2562 | 2566 | | | 2570d | 2573 | 2574M | 2575 | 2576 | 2594D | 2599 | 2601M | 260211 | 2604M | | | 2605 | 2608d | 2611M | 2613 | 2614 | 2617D | 2619 | 2620M | 262411 | 2625 | | | 2634 | 2639m | 2643 | 2644M | 2645 | 2734D | 2740 | 2743 | 2744 | 2747D | | | 2752 | 2756 | 2766M | 2767 | 2769 | 2770 | 2775 | 2776 | 2777 | 2779 | | | 2782 | 2791d | 2794 | 2797D | 2855 | 2894D | 2897M | 2900D | 2904 | 2906 | | | 2908 | 2909 | 2916 | 293111 | 2934D | 2937 | 2940M | 2942 | 2957D | 2975 | | xfered_domai | 562D | 1499 | 3338 | | | | | | - | | | xfered_local | 564D | 1809 | 1825 | 3340 | | | | | | | | xfered_proce | 562D | 1820 | 3339 | | | | | | | | | xferq — | 3157D | 3191 | 3204 | 3233 | 3282 | 3311 | | | | | | у | 443D | 446 | 447M | 448 | 2095D | 2101 | 2106 | | | | ## SIMULATION OF NETWORK WITH 1 SITES AND WITH 6 CONSOLES DIRECTLY CONNECTED SITES AND DISK: COPYING OF CODE PERFORMED: BIAS TOWARDS PROCESSOR UTILIZATION \* PERIOD OF SIMULATION (SECS) =2000 NUMBER OF SYSTEM DOMAINS = 20 NUMBER OF COMPILERS = 2 \* MEMORY SIZE = 128000BYTES SIZE DIVIDER CONSTANT= 1024 LOAD SHEDDING FACTOR= 2 MAXIMUM MIGRATIONS= 0 \* LARGE DOMAINS NOT ALLOWED TO START WHEN GREATEST FREE MEMORY IS LESS THAN 32500 OR NUMBER IN SYSTEM IS GREATER THAN 4 \* CONSOLE CONTROL SITE = 1 NUMBER OF DISKS = 1 DISK BUFFERS = 3 DISK SITE(S) = 1 \* TIME SLICE -100MSECS. LONG TIME SLICE = 500MSECS. COMMUNICATION FREQUENCY (MHZ) = 1.00 RANDOM NUMBER SEED = 787 113397709 DISKHANDLER IMPOTENT START OF RUN NUMBER OF CONSOLES IN THINKING STATE 4 NUMBER AWAITING ENTRY TO SYSTEM 0 END OF RUN NUMBER OF CONSOLES IN THINKING STATE 4 NUMBER AWAITING ENTRY TO SYSTEM 0 ### UTILIZATION OF PROCESSORS #### SITE 1 84780 MAXIMUM 123850 TOTAL IDLE TIME 372.1 AVERAGE MEMORY USE NUMBER OF CHANGES OF DOMAIN 11656 NUMBER OF TRANSFERED DOMAINS O NUMBER OF TRANSFERED PROCESSORS 1941 NUMBER OF FORCED MIGRATIONS O NUMBER OF PROCESSORS BLOCKED ON ENTRY TO NETWORK 12 TRANSFERED LOCAL SEGMENTS NUMBER OF INCARNATIONS BLOCKED WAITING FOR SPACE O RESPONSE TIMES NUMBER OF COMPLETED SHORT COMMANDS 182 NUMBER OF RESPONSE TIMES OVER 2 SECS 2 NUMBER OF RESPONSE TIMES OVER 5 SECS REGRESSION ANALYSIS OF NON TRIVIAL SERVICE TIMES VERSUS RESPONSE TIME NUMBER OF DATA POINTS 65 MEAN OF NON TRIVIAL SERVICE TIMES 21.5 MEAN OF RESPONSE TIME 61.0 RESIDUAL STANDARD DEVIATION 35.42 ESTIMATE OF REGRESSION COEFFICIENT 2.33 INTERCEPT 10.90 STANDARD DEVIATION OF REGRESSION COEFFICIENT 0.16 CORRELATION COEFFICIENT 0.883 # COMMUNICATIONS SUBSYSTEM NUMBER OF BYTES TRANSFERED 42470472 NUMBER OF CONTROL MESSAGES (32 BYTES) SENT 12823 DISK PERFORMANCE NUMBER OF BYTES TRANSFERED 42060136 NUMBER OF COMPLETED TRANSFERS 5569 TOTAL DISK IDLE TIME 1702.8 | CONSOLE 1 | | | | | | | | | |--------------------------------------|------------------------|--------------|--------------|-------|-----------------------------------------|-------------|-----------|-----| | TOTAL THINKING TIME 1219.0 | TOTAL RESPONSE TIME | 781.0 TOTAL | SERVICE TIME | 282.3 | NUMBER OF | COMPLETED ( | COMMANDS | 40 | | CONSOLE 2 TOTAL THINKING TIME 1033.6 | TOTAL RESPONSE TIME | 966 4 TOTAL | SERVICE TIME | 322.5 | NUMBER OF | COMPLETED ( | COMMANDS | 40 | | CONSOLE 3 | TOTAL RESTONDE TIME | 700.4 TOTAL | OBMITOR TIME | 32213 | .,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, | | | . • | | TOTAL THINKING TIME 1097.3 | TOTAL RESPONSE TIME | 902.7 TOTAL | SERVICE TIME | 338.9 | NUMBER OF | COMPLETED ( | COMMANDS | 39 | | CONSOLE 4 | TOTAL DESCRIPTION MINE | EQ. () MOMAI | CEDUTOR TIME | 147.1 | MUMPED OF | COMPLETED ( | COMMANDS | 1.6 | | TOTAL THINKING TIME 1405.4 | TOTAL RESPONSE TIME | 594.6 TOTAL | SERVICE TIME | 147.1 | NUMBER OF | COUPLETED | JOHNMINDS | 40 | | CONSOLE 5 TOTAL THINKING TIME 848.2 | TOTAL RESPONSE TIME | 1151.8 TOTAL | SERVICE TIME | 382.1 | NUMBER OF | COMPLETED ( | COMMANDS | 21 | | CONSOLE 6 | | | | | | | | | | TOTAL THINKING TIME 1636.0 | TOTAL RESPONSE TIME | 364.0 TOTAL | SERVICE TIME | 144.4 | NUMBER OF | COMPLETED ( | COMMANDS | 61 | GRAND TOTAL OF RESPONSE TIMES 4760 GRAND TOTAL OF SERVICE TIMES 1617 PERFORMANCE MEASURE 2.94 FRACTION USEFUL PROCESSOR UTILIZATION 0.809 TOTAL IDLE TIME 4.8 ### SIMULATION OF NETWORK WITH 6 SITES AND WITH 48 CONSOLES AVERAGE MEMORY USE DIRECTLY CONNECTED SITES AND DISK: COPYING OF CODE PERFORMED: BIAS TOWARDS PROCESSOR UTILIZATION \* PERIOD OF SIMULATION (SECS) = 250 NUMBER OF SYSTEM DOMAINS = 21 NUMBER OF COMPILERS = 2 \* MEMORY SIZE = 128000BYTES SIZE DIVIDER CONSTANT= 1024 LOAD SHEDDING FACTOR= 2 MAXIMUM MIGRATIONS= 5 \* LARGE DOMAINS NOT ALLOWED TO START WHEN GREATEST FREE MEMORY IS LESS THAN 38000 OR NUMBER IN SYSTEM IS GREATER THAN 24 \* CONSOLE CONTROL SITE= 1 NUMBER OF DISKS= 2 DISK BUFFERS= 3 DISK SITE(S)= 3 6 \* TIME SLICE =100MSECS. LONG TIME SLICE = 500MSECS. COMMUNICATION FREQUENCY (MHZ) = 1.00 RANDOM NUMBER SEED = 787 START OF RUN NUMBER OF CONSOLES IN THINKING STATE 34 NUMBER AWAITING ENTRY TO SYSTEM 0 END OF RUN NUMBER OF CONSOLES IN THINKING STATE 26 NUMBER AWAITING ENTRY TO SYSTEM O UTILIZATION OF PROCESSORS SITE 1 TOTAL IDLE TIME 22,8 AVERAGE MEMORY USE 85923 MAXIMUM 127961 SITE 2 TOTAL IDLE TIME 11.8 AVERAGE MEMORY USE 85319 MAXIMUM 126082 SITE 3 TOTAL IDLE TIME AVERAGE MEMORY USE 88036 MAXIMUM 127633 SITE 4 TOTAL IDLE TIME 15.3 AVERAGE MEMORY USE 77067 MAXINUM 127356 SITE 5 TOTAL IDLE TIME 12.3 AVERAGE MEMORY USE 78316 MAXIMUM 126079 SITE 6 NUMBER OF CHANGES OF DOMAIN 9896 NUMBER OF TRANSFERED DOMAINS 61 NUMBER OF TRANSFERED PROCESSORS 6369 NUMBER OF TRANSFERED LOCAL SEGMENTS 5187 NUMBER OF FORCED MIGRATIONS 1461 NUMBER OF PROCESSORS BLOCKED ON ENTRY TO NETWORK ON NUMBER OF INCARNATIONS BLOCKED WAITING FOR SPACE OR RESPONSE TIMES MAXIMUM 126745 81423 NUMBER OF COMPLETED SHORT COMMANDS 187 NUMBER OF RESPONSE TIMES OVER 2 SECS 2 NUMBER OF RESPONSE TIMES OVER 5 SECS 0 REGRESSION ANALYSIS OF NON TRIVIAL SERVICE TIMES VERSUS RESPONSE TIME NUMBER OF DATA POINTS 59 MEAN OF NON TRIVIAL SERVICE TIMES 16.4 MEAN OF RESPONSE TIME 49.7 RESIDUAL STANDARD DEVIATION 13.50 ESTIMATE OF REGRESSION COEFFICIENT 2.92 INTERCEPT 1.68 STANDARD DEVIATION OF REGRESSION COEFFICIENT 0.11 CORRELATION COEFFICIENT 0.965 | | | | | | | | | | | | | | | • | |---------------------------|----------|---------|-----------------|-----------------|-----------|---------|-----------------------------------------|---------|-------|----------|-------------|------------|-------------|-----| | COMMUNICATIONS SUBS | SYSTEM | | | | | | | | | | | | | | | NUMBER OF BYTES | TRANS | FERED | 55422984 | NUMBER OF | CONTROL M | ESSAGES | 32 BY | TES) SE | NT 29 | 604 | | | | 0 | | DISK PERFORMANCE | | | | | | | | | | | | | | • | | NUMBER OF BYTES | TRANS | FERED | 18885714 | NUMBER OF | COMPLETED | TRANSE | FERS | 2563 | TOTAL | DISK ID | LE TI | ME 115. | 2 | | | DISK PERFORMANCE | mp vo | mmn mix | 15660000 | | | | | | | | | | | | | NUMBER OF BYTES | TRANS | FERED | 15662283 | NUMBER OF | COMPLETED | TRANSF | FERS | 2116 | TOTAL | DISK ID | LE TI | ME 138. | 9 | | | CONSOLE 1 | TT ACE | 2/2 0 | TOTAL D | CODONOR MINE | 7.0 | momit | 4 m m m m m m m m m m m m m m m m m m m | mrun | | | | | | ١ - | | TOTAL THINKING CONSOLE 2 | LIFIE | 242.8 | TOTAL R | ESPONSE TIME | 7.2 | TOTAL | SERVICE | TIME | 4.4 | NUMBER | OF C | COMPLETED | COMMANDS | 5 | | TOTAL THINKING | TIME | 204 4 | ש זאדאד ט | ESPONSE TIME | 45.6 | TOTAL | SERVICE | TIME | 17.6 | MUMBER | 05 0 | OWDI EMIL | 00000000 | , | | CONSOLE 3 | LIME | 204.4 | IOIAL K | arri acnorea. | 43.0 | TOTAL | SEKVICE | LIPE | 17.0 | NUMBER | OF C | OMPLETED | COMMANDS | 6 | | TOTAL THINKING | TIME | 24.3 | TOTAL R | ESPONSE TIME | 225 7 | TOTAL | SERVICE | TIME | 63.4 | NUMBED | 0E 0 | יחשטו בדבה | COMMANDS | 1 | | CONSOLE 4 | 1 11111 | 24.5 | TOTAL K | EDIONDE TIME | 223.1 | TOTAL | BULLION | TIME | 03.4 | NOTIBER | Or C | OMPLEIED | COMMANDS | 1 | | TOTAL THINKING | TIME | 124.2 | TOTAL R | ESPONSE TIME | 125.8 | TOTAL. | SERVICE | TIME | 33.4 | NUMBER | OF C | יחאטו בדבה | COMMANDS | ٠, | | CONSOLE 5 | | | | | 12310 | 1011111 | DBKTIOD | 111111 | 33.4 | NOTIDER | Or C | Orn LLIED | COMMINDS | 4 | | TOTAL THINKING | TIME | 204.9 | TOTAL R | ESPONSE TIME | 45.1 | TOTAL | SERVICE | TIME | 18.9 | NUMBER | OF C | OMPLETED | COMMANDS | 13 | | CONSOLE 6 | | | | | | | | | | | • | | 0011121120 | 13 | | TOTAL THINKING | TIME | 98.8 | TOTAL R | ESPONSE TIME | 151.2 | TOTAL | SERVICE | TIME . | 37.2 | NUMBER | OF C | OMPLETED | COMMANDS | 5 | | CONSOLE 7 | | | | | | | | | | | | | 0028.50 | • | | TOTAL THINKING | TIME | 169.2 | TOTAL R | ESPONSE TIME | 80.8 | TOTAL | SERVICE | TIME | 31.6 | NUMBER | OF C | OMPLETED | COMMANDS | 6 | | CONSOLE 8 | | | | | | | | | | | | | | • | | TOTAL THINKING | TIME | 208.7 | TOTAL R | ESPONSE TIME | 41.3 | TOTAL | SERVICE | TIME | 9.4 | NUMBER | OF C | OMPLETED | COMMANDS | 8 | | CONSOLE 9 | | | | | | | | | | | | | | | | TOTAL THINKING | TIME | 248.8 | TOTAL R | ESPONSE TIME | 1.2 | TOTAL | SERVICE | TIME | 0.3 | NUMBER | OF C | OMPLETED | COMMANDS | 5 | | CONSOLE 10 | | | | | | | | | | | | | | | | TOTAL THINKING | TIME | 235.3 | TOTAL R | ESPONSE TIME | 14.7 | TOTAL | SERVICE | TIME | 3.5 | NUMBER | OF C | OMPLETED | COMMANDS | 10 | | CONSOLE 11 | m T 1411 | 005 6 | | | | | | | | | | | | | | TOTAL THINKING CONSOLE 12 | TIME | 225.6 | TOTAL R | ESPONSE TIME | 24.4 | TOTAL | SERVICE | TIME | 5.7 | NUMBER | OF C | OMPLETED | COMMANDS | 7 | | TOTAL THINKING | TIME | 23.3 | TOTAL D | PODONOE STAR | 226 7 | momit | | | | | | | | | | CONSOLE 13 | LIFIE | 23.3 | IOIAL R | ESPONSE TIME | 226.7 | TOTAL | SERVICE | TIME | 91.0 | NUMBER | OF C | OMPLETED | COMMANDS | 1 | | TOTAL THINKING | TIME | 158.6 | <b>ፐ</b> ለፕል፤ D | ESPONSE TIME | 01.4 | TOTAL | CEDUTOR | TTME | 20.6 | | | | | | | CONSOLE 14 | TIME | 130.0 | TOTAL R | ESPONSE TIME | 91.4 | TOTAL | SERVICE | TIME | 30.6 | NUMBER | OF C | OMPLETED | COMMANDS | 9 | | TOTAL THINKING | TIME | 77.7 | TOTAL R | ESPONSE TIME | 172 3 | TOTAL | SERVICE | TIME | 45.2 | MILMORD | OF C | OWDI ETEN | 60101111111 | ^ | | CONSOLE 15 | | | ZOZIII K | 201011011 11111 | 114.3 | TOTAL | PULLICE | TIPE | 47.2 | NUMBER | or C | OMPLETED | COMMANDS | 2 | | TOTAL THINKING | TIME | 216.3 | TOTAL R | ESPONSE TIME | 33.7 | TOTAL. | SERVICE | TIME | 11.9 | NUMBER | <b>ዕድ</b> ሮ | OMPLETED | COMMANDS | 8 | | CONSOLE 16 | | | | | 231. | | | - 41111 | *** / | Madriden | OF C | OURTEIED | COULTAIND2 | 0 | | | | | | | | | | | | | | | | | | | | | | | | · | | |----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | • | | | | | | | | | | | | | | | | | 146.4 | TOTAL RESPONSE TIME | 103.6 | TOTAL SERVICE TÎME | 25.5 | NUMBER OF COMPLETED COMMANDS | 5 . | | | | | | | | | | | | 238.8 | TOTAL RESPONSE TIME | 11.2 | TOTAL SERVICE TIME | 3.5 | NUMBER OF COMPLETED COMMANDS | 8 | | | | | | | | , | | | | 243.7 | TOTAL RESPONSE TIME | 6.3 | TOTAL SERVICE TIME | 2.7 | NUMBER OF COMPLETED COMMANDS | 6 | | | 50.0 | TOTAL BECDONOR TIME | 101 0 | TOTAL GENUTES TIVE | 50.0 | NUMBER OF COMPANIES COMMANDS | | | | 39.0 | TOTAL RESPONSE TIME | 191.0 | TOTAL SERVICE TIME | 52.8 | NUMBER OF COMPLETED COMMANDS | 4 | | | 220.0 | TOTAL DECRONCE TIME | 20.0 | TOTAL CENTRE TIME | 0 0 | NUMBER OF COMPLETED COMMUNIC | | | | 230.0 | TOTAL RESPONSE TIME | 20.0 | TOTAL SERVICE TIME | 0.9 | NUMBER OF COMPLETED COMMANDS | . 8 | | | 214 0 | TOTAL RESPONSE TIME | 36 n | TOTAL SERVICE TIME | 13 / | NUMBED OF COMPLETED COMMANDS | 8 | | | 214.0 | TOTAL RESTORDE TIME | 30.0 | TOTAL SERVICE TIME | 13.4 | MONDER OF CONFERENCE CONMANDS | Q | | | 76.6 | TOTAL RESPONSE TIME | 173.4 | TOTAL SERVICE TIME | 49 2 | NUMBER OF COMPLETED COMMANDS | 2 | | _ | ,,,, | TOTAL REGIONOL TIME | 27314 | TOTAL BERVIOL TIME | 47.2 | NOTIBER OF COMMENDS | 2 | | | 249.0 | TOTAL RESPONSE TIME | 1.0 | TOTAL SERVICE TIME | 0.2 | NUMBER OF COMPLETED COMMANDS | 2 | | | | | -, • | | 012 | | - | | | 236.8 | TOTAL RESPONSE TIME | 13.2 | TOTAL SERVICE TIME | 2.4 | NUMBER OF COMPLETED COMMANDS | 3 · | | CONSOLE 25 | | | | | | | • | | TOTAL THINKING TIME | 248.8 | TOTAL RESPONSE TIME | 1.2 | TOTAL SERVICE TIME | 0.7 | NUMBER OF COMPLETED COMMANDS | 7 | | CÓNSOLE 26 | | | | | | | | | TOTAL THINKING TIME | 2.2 | TOTAL RESPONSE TIME | 247.8 | TOTAL SERVICE TIME | 69.3 | NUMBER OF COMPLETED COMMANDS | 0 | | | | | | | | | | | | 0.0 | TOTAL RESPONSE TIME | 250.0 | TOTAL SERVICE TIME | 70.6 | NUMBER OF COMPLETED COMMANDS | 0 | | | 225 1 | TOTAL DECRONCE TIME | 1/ 0 | TOTAL GERMAN MYME | , , | William OF Column Street Columns | • - | | | 233.1 | IOTAL RESPONSE TIME | 14.9 | TOTAL SERVICE TIME | 4.3 | NUMBER OF COMPLETED COMMANDS | - 10 | | | 02.2 | TOTAL DECRONCE TIME | 166 7 | TOTAL SERVICE TIME | /.7 O | NUMBER OF COMPLETED COMMANDS | 3 | | | 03.3 | TOTAL RESPONSE TIME | 100.7 | TOTAL SERVICE TIME | 4/.0 | NORDER OF CORPLETED CORMANDS | 3 | | | 190.3 | TOTAL RESPONSE TIME | 59.7 | TOTAL SERVICE TIME | 16.2 | NUMBER OF COMPLETED COMMANDS | 6 | | | | 1011111 1111111111111111111111111111111 | | | 1012 | TOTAL OF COM ESTAS COMMENSS | 9 | | TOTAL THINKING TIME | 167.1 | TOTAL RESPONSE TIME | 82.9 | TOTAL SERVICE TIME | 24.6 | NUMBER OF COMPLETED COMMANDS | 4 | | CONSOLE 32 | • | | | | • | | | | TOTAL THINKING TIME | 219.3 | TOTAL RESPONSE TIME | 30.7 | TOTAL SERVICE TIME | 8.8 | NUMBER OF COMPLETED COMMANDS | 8 | | CONSOLE 33 | | | | | | | | | | 184.3 | TOTAL RESPONSE TIME | 65.7 | TOTAL SERVICE TIME | 26.9 | NUMBER OF COMPLETED COMMANDS | 6 | | CONSOLE 34 | | | | | | | | | | 211.1 | TOTAL RESPONSE TIME | 38.9 | TOTAL SERVICE TIME | 10.3 | NUMBER OF COMPLETED COMMANDS | 6 | | | 226.2 | MOTAL DEGROVES TO | 12. | moment appearant masses | · · | WINDER OF COURT TEE COMMITTEE | , | | | 236.9 | TOTAL RESPONSE TIME | 13.1 | TOTAL SERVICE TIME | 5.6 | NUMBER OF COMPLETED COMMANDS | 4 | | | 230 8 | TOTAL DECHONCE TIME | 10 2 | TOTAL SERVICE TIME | <i>/</i> . 5 | NUMBER OF COMPLETED CONVENDS | 0 | | TOTAL INTINCTIO TIME | 430.0 | TOTAL RESPONSE TIME | 17.4 | TOTAL SERVICE TIME | 4.) | NUMBER OF COMPLETED COMMANDS | 8 | | | CONSOLE 19 TOTAL THINKING TIME CONSOLE 20 TOTAL THINKING TIME CONSOLE 21 TOTAL THINKING TIME CONSOLE 22 TOTAL THINKING TIME CONSOLE 23 TOTAL THINKING TIME CONSOLE 24 TOTAL THINKING TIME CONSOLE 25 TOTAL THINKING TIME CONSOLE 26 TOTAL THINKING TIME CONSOLE 27 TOTAL THINKING TIME CONSOLE 27 TOTAL THINKING TIME CONSOLE 28 TOTAL THINKING TIME CONSOLE 29 TOTAL THINKING TIME CONSOLE 30 TOTAL THINKING TIME CONSOLE 31 TOTAL THINKING TIME CONSOLE 32 TOTAL THINKING TIME CONSOLE 33 TOTAL THINKING TIME CONSOLE 34 TOTAL THINKING TIME CONSOLE 34 TOTAL THINKING TIME CONSOLE 35 TOTAL THINKING TIME CONSOLE 35 TOTAL THINKING TIME | CONSOLE 17 TOTAL THINKING TIME 238.8 CONSOLE 18 TOTAL THINKING TIME 243.7 CONSOLE 19 TOTAL THINKING TIME 59.0 CONSOLE 20 TOTAL THINKING TIME 230.0 CONSOLE 21 TOTAL THINKING TIME 214.0 CONSOLE 22 TOTAL THINKING TIME 76.6 CONSOLE 23 TOTAL THINKING TIME 249.0 CONSOLE 24 TOTAL THINKING TIME 236.8 CONSOLE 25 TOTAL THINKING TIME 248.8 CONSOLE 25 TOTAL THINKING TIME 248.8 CONSOLE 26 TOTAL THINKING TIME 2.2 CONSOLE 27 TOTAL THINKING TIME 2.2 CONSOLE 28 TOTAL THINKING TIME 235.1 CONSOLE 29 TOTAL THINKING TIME 33.3 CONSOLE 30 TOTAL THINKING TIME 190.3 CONSOLE 31 TOTAL THINKING TIME 167.1 CONSOLE 32 TOTAL THINKING TIME 167.1 CONSOLE 33 TOTAL THINKING TIME 184.3 CONSOLE 34 TOTAL THINKING TIME 184.3 CONSOLE 35 TOTAL THINKING TIME 211.1 CONSOLE 35 TOTAL THINKING TIME 211.1 | CONSOLE 17 TOTAL THINKING TIME 238.8 TOTAL RESPONSE TIME CONSOLE 18 TOTAL THINKING TIME 243.7 TOTAL RESPONSE TIME CONSOLE 19 TOTAL THINKING TIME 59.0 TOTAL RESPONSE TIME CONSOLE 20 TOTAL THINKING TIME 230.0 TOTAL RESPONSE TIME CONSOLE 21 TOTAL THINKING TIME 214.0 TOTAL RESPONSE TIME CONSOLE 22 TOTAL THINKING TIME 249.0 TOTAL RESPONSE TIME CONSOLE 23 TOTAL THINKING TIME 249.0 TOTAL RESPONSE TIME CONSOLE 24 TOTAL THINKING TIME 236.8 TOTAL RESPONSE TIME CONSOLE 25 TOTAL THINKING TIME 248.8 TOTAL RESPONSE TIME CONSOLE 26 TOTAL THINKING TIME 248.8 TOTAL RESPONSE TIME CONSOLE 27 TOTAL THINKING TIME 2.2 TOTAL RESPONSE TIME CONSOLE 28 TOTAL THINKING TIME 2.2 TOTAL RESPONSE TIME CONSOLE 28 TOTAL THINKING TIME 235.1 TOTAL RESPONSE TIME CONSOLE 29 TOTAL THINKING TIME 33.3 TOTAL RESPONSE TIME CONSOLE 30 TOTAL THINKING TIME 190.3 TOTAL RESPONSE TIME CONSOLE 31 TOTAL THINKING TIME 167.1 TOTAL RESPONSE TIME CONSOLE 33 TOTAL THINKING TIME 167.1 TOTAL RESPONSE TIME CONSOLE 33 TOTAL THINKING TIME 184.3 TOTAL RESPONSE TIME CONSOLE 33 TOTAL THINKING TIME 184.3 TOTAL RESPONSE TIME CONSOLE 33 TOTAL THINKING TIME 184.3 TOTAL RESPONSE TIME CONSOLE 34 TOTAL THINKING TIME 184.3 TOTAL RESPONSE TIME CONSOLE 35 TOTAL THINKING TIME 211.1 TOTAL RESPONSE TIME CONSOLE 35 TOTAL THINKING TIME 236.9 TOTAL RESPONSE TIME CONSOLE 35 TOTAL THINKING TIME 236.9 TOTAL RESPONSE TIME CONSOLE 36 | CONSOLE 17 TOTAL THINKING TIME 238.8 TOTAL RESPONSE TIME 11.2 CONSOLE 18 TOTAL THINKING TIME 243.7 TOTAL RESPONSE TIME 6.3 CONSOLE 19 TOTAL THINKING TIME 59.0 TOTAL RESPONSE TIME 191.0 CONSOLE 20 TOTAL THINKING TIME 230.0 TOTAL RESPONSE TIME 20.0 CONSOLE 21 TOTAL THINKING TIME 214.0 TOTAL RESPONSE TIME 36.0 CONSOLE 22 TOTAL THINKING TIME 76.6 TOTAL RESPONSE TIME 173.4 CONSOLE 23 TOTAL THINKING TIME 249.0 TOTAL RESPONSE TIME 1.0 CONSOLE 24 TOTAL THINKING TIME 236.8 TOTAL RESPONSE TIME 13.2 CONSOLE 25 TOTAL THINKING TIME 248.8 TOTAL RESPONSE TIME 1.2 CONSOLE 26 TOTAL THINKING TIME 2.2 TOTAL RESPONSE TIME 247.8 CONSOLE 27 TOTAL THINKING TIME 2.2 TOTAL RESPONSE TIME 250.0 CONSOLE 28 TOTAL THINKING TIME 2.35.1 TOTAL RESPONSE TIME 250.0 CONSOLE 29 TOTAL THINKING TIME 235.1 TOTAL RESPONSE TIME 14.9 CONSOLE 29 TOTAL THINKING TIME 83.3 TOTAL RESPONSE TIME 14.9 CONSOLE 30 TOTAL THINKING TIME 190.3 TOTAL RESPONSE TIME 59.7 CONSOLE 31 TOTAL THINKING TIME 167.1 TOTAL RESPONSE TIME 82.9 CONSOLE 33 TOTAL THINKING TIME 167.1 TOTAL RESPONSE TIME 30.7 CONSOLE 34 TOTAL THINKING TIME 184.3 TOTAL RESPONSE TIME 65.7 CONSOLE 35 TOTAL THINKING TIME 211.1 TOTAL RESPONSE TIME 38.9 CONSOLE 35 TOTAL THINKING TIME 211.1 TOTAL RESPONSE TIME 38.9 CONSOLE 35 TOTAL THINKING TIME 236.9 TOTAL RESPONSE TIME 38.9 CONSOLE 36 | CONSOLE 17 TOTAL THINKING TIME 238.8 TOTAL RESPONSE TIME 11.2 TOTAL SERVICE TIME CONSOLE 18 TOTAL THINKING TIME 243.7 TOTAL RESPONSE TIME 6.3 TOTAL SERVICE TIME CONSOLE 19 TOTAL THINKING TIME 59.0 TOTAL RESPONSE TIME 191.0 TOTAL SERVICE TIME CONSOLE 20 TOTAL THINKING TIME 230.0 TOTAL RESPONSE TIME 20.0 TOTAL SERVICE TIME CONSOLE 21 TOTAL THINKING TIME 214.0 TOTAL RESPONSE TIME 36.0 TOTAL SERVICE TIME CONSOLE 22 TOTAL THINKING TIME 76.6 TOTAL RESPONSE TIME 173.4 TOTAL SERVICE TIME CONSOLE 23 TOTAL THINKING TIME 249.0 TOTAL RESPONSE TIME 1.0 TOTAL SERVICE TIME CONSOLE 24 TOTAL THINKING TIME 236.8 TOTAL RESPONSE TIME 1.0 TOTAL SERVICE TIME CONSOLE 25 TOTAL THINKING TIME 248.8 TOTAL RESPONSE TIME 13.2 TOTAL SERVICE TIME CONSOLE 25 TOTAL THINKING TIME 248.8 TOTAL RESPONSE TIME 1.2 TOTAL SERVICE TIME CONSOLE 26 TOTAL THINKING TIME 2.2 TOTAL RESPONSE TIME 1.2 TOTAL SERVICE TIME CONSOLE 27 TOTAL THINKING TIME 2.2 TOTAL RESPONSE TIME 247.8 TOTAL SERVICE TIME CONSOLE 27 TOTAL THINKING TIME 2.2 TOTAL RESPONSE TIME 247.8 TOTAL SERVICE TIME CONSOLE 28 TOTAL THINKING TIME 235.1 TOTAL RESPONSE TIME 249.9 TOTAL SERVICE TIME CONSOLE 28 TOTAL THINKING TIME 235.1 TOTAL RESPONSE TIME 14.9 TOTAL SERVICE TIME CONSOLE 30 TOTAL THINKING TIME 190.3 TOTAL RESPONSE TIME 166.7 TOTAL SERVICE TIME CONSOLE 31 TOTAL THINKING TIME 190.3 TOTAL RESPONSE TIME 59.7 TOTAL SERVICE TIME CONSOLE 31 TOTAL THINKING TIME 167.1 TOTAL RESPONSE TIME 30.7 TOTAL SERVICE TIME CONSOLE 33 TOTAL THINKING TIME 167.1 TOTAL RESPONSE TIME 30.7 TOTAL SERVICE TIME CONSOLE 34 TOTAL THINKING TIME 184.3 TOTAL RESPONSE TIME 30.7 TOTAL SERVICE TIME CONSOLE 35 TOTAL THINKING TIME 184.3 TOTAL RESPONSE TIME 30.7 TOTAL SERVICE TIME CONSOLE 35 TOTAL THINKING TIME 211.1 TOTAL RESPONSE TIME 38.9 TOTAL SERVICE TIME CONSOLE 35 TOTAL THINKING TIME 211.1 TOTAL RESPONSE TIME 38.9 TOTAL SERVICE TIME CONSOLE 36 | CONSOLE 17 TOTAL THINKING TIME 238.8 TOTAL RESPONSE TIME 11.2 TOTAL SERVICE TIME 3.5 CONSOLE 18 TOTAL THINKING TIME 243.7 TOTAL RESPONSE TIME 6.3 TOTAL SERVICE TIME 2.7 CONSOLE 19 TOTAL THINKING TIME 59.0 TOTAL RESPONSE TIME 191.0 TOTAL SERVICE TIME 52.8 CONSOLE 20 TOTAL THINKING TIME 214.0 TOTAL RESPONSE TIME 20.0 TOTAL SERVICE TIME 8.9 CONSOLE 21 TOTAL THINKING TIME 214.0 TOTAL RESPONSE TIME 36.0 TOTAL SERVICE TIME 13.4 CONSOLE 22 TOTAL THINKING TIME 249.0 TOTAL RESPONSE TIME 173.4 TOTAL SERVICE TIME 49.2 CONSOLE 23 TOTAL THINKING TIME 249.0 TOTAL RESPONSE TIME 1.0 TOTAL SERVICE TIME 0.2 CONSOLE 25 TOTAL THINKING TIME 248.8 TOTAL RESPONSE TIME 13.2 TOTAL SERVICE TIME 2.4 CONSOLE 25 TOTAL THINKING TIME 248.8 TOTAL RESPONSE TIME 1.2 TOTAL SERVICE TIME 0.7 CONSOLE 26 TOTAL THINKING TIME 2.2 TOTAL RESPONSE TIME 1.2 TOTAL SERVICE TIME 0.7 CONSOLE 27 TOTAL THINKING TIME 2.2 TOTAL RESPONSE TIME 247.8 TOTAL SERVICE TIME 69.3 CONSOLE 27 TOTAL THINKING TIME 2.2 TOTAL RESPONSE TIME 247.8 TOTAL SERVICE TIME 69.3 CONSOLE 28 TOTAL THINKING TIME 235.1 TOTAL RESPONSE TIME 250.0 TOTAL SERVICE TIME 70.6 CONSOLE 28 TOTAL THINKING TIME 235.1 TOTAL RESPONSE TIME 14.9 TOTAL SERVICE TIME 4.3 CONSOLE 29 TOTAL THINKING TIME 235.1 TOTAL RESPONSE TIME 15.7 TOTAL SERVICE TIME 4.3 CONSOLE 30 TOTAL THINKING TIME 190.3 TOTAL RESPONSE TIME 59.7 TOTAL SERVICE TIME 47.8 CONSOLE 30 TOTAL THINKING TIME 167.1 TOTAL RESPONSE TIME 30.7 TOTAL SERVICE TIME 24.6 CONSOLE 33 TOTAL THINKING TIME 184.3 TOTAL RESPONSE TIME 30.7 TOTAL SERVICE TIME 24.6 CONSOLE 34 TOTAL THINKING TIME 219.1 TOTAL RESPONSE TIME 38.9 TOTAL SERVICE TIME 26.9 CONSOLE 35 TOTAL THINKING TIME 211.1 TOTAL RESPONSE TIME 38.9 TOTAL SERVICE TIME 26.9 CONSOLE 36 TOTAL THINKING TIME 216.1 TOTAL RESPONSE TIME 38.9 TOTAL THINKING TIME 216.1 TOTAL RESPONSE TIME 38.9 TOTAL SERVICE TIME 26.9 CONSOLE 36 | CONSOLE 17 TOTAL THINKING TIME 238.8 TOTAL RESPONSE TIME 11.2 TOTAL SERVICE TIME 3.5 NUMBER OF COMPLETED COMMANDS CONSOLE 18 TOTAL THINKING TIME 243.7 TOTAL RESPONSE TIME 6.3 TOTAL SERVICE TIME 2.7 NUMBER OF COMPLETED COMMANDS CONSOLE 19 TOTAL THINKING TIME 59.0 TOTAL RESPONSE TIME 191.0 TOTAL SERVICE TIME 52.8 NUMBER OF COMPLETED COMMANDS CONSOLE 20 TOTAL THINKING TIME 230.0 TOTAL RESPONSE TIME 20.0 TOTAL SERVICE TIME 8.9 NUMBER OF COMPLETED COMMANDS CONSOLE 21 TOTAL THINKING TIME 214.0 TOTAL RESPONSE TIME 36.0 TOTAL SERVICE TIME 8.9 NUMBER OF COMPLETED COMMANDS CONSOLE 22 TOTAL THINKING TIME 249.0 TOTAL RESPONSE TIME 173.4 TOTAL SERVICE TIME 49.2 NUMBER OF COMPLETED COMMANDS CONSOLE 23 TOTAL THINKING TIME 249.0 TOTAL RESPONSE TIME 1.0 TOTAL SERVICE TIME 0.2 NUMBER OF COMPLETED COMMANDS CONSOLE 24 TOTAL THINKING TIME 248.8 TOTAL RESPONSE TIME 13.2 TOTAL SERVICE TIME 2.4 NUMBER OF COMPLETED COMMANDS CONSOLE 25 TOTAL THINKING TIME 248.8 TOTAL RESPONSE TIME 1.2 TOTAL SERVICE TIME 0.7 NUMBER OF COMPLETED COMMANDS CONSOLE 26 TOTAL THINKING TIME 2.2 TOTAL RESPONSE TIME 1.2 TOTAL SERVICE TIME 0.7 NUMBER OF COMPLETED COMMANDS CONSOLE 26 TOTAL THINKING TIME 2.2 TOTAL RESPONSE TIME 1.2 TOTAL SERVICE TIME 0.7 NUMBER OF COMPLETED COMMANDS CONSOLE 26 TOTAL THINKING TIME 2.35.1 TOTAL RESPONSE TIME 1.4 TOTAL SERVICE TIME 4.3 NUMBER OF COMPLETED COMMANDS CONSOLE 28 TOTAL THINKING TIME 2.35.1 TOTAL RESPONSE TIME 14.9 TOTAL SERVICE TIME 4.3 NUMBER OF COMPLETED COMMANDS CONSOLE 30 TOTAL THINKING TIME 8.3.3 TOTAL RESPONSE TIME 1.4 TOTAL SERVICE TIME 4.3 NUMBER OF COMPLETED COMMANDS CONSOLE 31 TOTAL THINKING TIME 1.4 TOTAL RESPONSE TIME 1.4 TOTAL SERVICE TIME 1.5 NUMBER OF COMPLETED COMMANDS CONSOLE 31 TOTAL THINKING TIME 1.4 TOTAL RESPONSE TIME 3.0 TOTAL SERVICE TIME 4.3 NUMBER OF COMPLETED COMMANDS CONSOLE 31 TOTAL THINKING TIME 1.4 TOTAL RESPONSE TIME 3.0 TOTAL SERVICE TIME 4.3 NUMBER OF COMPLETED COMMANDS CONSOLE 31 TOTAL THINKING TIME 1.4 TOTAL RESPONSE TIME 3.0 TOTAL SERVICE TIME 4.6 NUMBER OF COMPLETED COMMANDS CONSOLE 31 T | | CONSOLE 37 | | • | | | | | |---------------------|-------|---------------------|-------|--------------------|------|---------------------------------| | TOTAL THINKING TIME | 67.8 | TOTAL RESPONSE TIME | 182.2 | TOTAL SERVICE TIME | 59.3 | NUMBER OF COMPLETED COMMANDS 2 | | CONSOLE 38 | | | | | | | | TOTAL THINKING TIME | 61.2 | TOTAL RESPONSE TIME | 188.8 | TOTAL SERVICE TIME | 50.3 | NUMBER OF COMPLETED COMMANDS 1 | | CONSOLE 39 | | | | | | | | TOTAL THINKING TIME | 113.3 | TOTAL RESPONSE TIME | 136.7 | TOTAL SERVICE TIME | 55.1 | NUMBER OF COMPLETED COMMANDS 5 | | CONSOLE 40 | | • | | | | | | TOTAL THINKING TIME | 160.5 | TOTAL RESPONSE TIME | 89.5 | TOTAL SERVICE TIME | 28.8 | NUMBER OF COMPLETED COMMANDS 5 | | CONSOLE 41 | | • | | | | | | TOTAL THINKING TIME | 231.5 | TOTAL RESPONSE TIME | 18.5 | TOTAL SERVICE TIME | 5.8 | NUMBER OF COMPLETED COMMANDS 6 | | CONSOLE 42 | | | | | | | | TOTAL THINKING TIME | 66.2 | TOTAL RESPONSE TIME | 183.8 | TOTAL SERVICE TIME | 66.1 | NUMBER OF COMPLETED COMMANDS 4 | | CONSOLE 43 | | | | | | | | | 110.9 | TOTAL RESPONSE TIME | 139.1 | TOTAL SERVICE TIME | 45.7 | NUMBER OF COMPLETED COMMANDS 2 | | CONSOLE 44 | | | | | | | | TOTAL THINKING TIME | 15.6 | TOTAL RESPONSE TIME | 234.4 | TOTAL SERVICE TIME | 98.2 | NUMBER OF COMPLETED COMMANDS 0 | | CONSOLE 45 | | · | | | | | | TOTAL THINKING TIME | 138.8 | TOTAL RESPONSE TIME | 111.2 | TOTAL SERVICE TIME | 34.1 | NUMBER OF COMPLETED COMMANDS 10 | | CONSOLE 46 | | | | | | | | TOTAL THINKING TIME | 51.1 | TOTAL RESPONSE TIME | 198.9 | TOTAL SERVICE TIME | 58.6 | NUMBER OF COMPLETED COMMANDS 1 | | CONSOLE 47 | | | | | | | | TOTAL THINKING TIME | 181.2 | TOTAL RESPONSE TIME | 68.8 | TOTAL SERVICE TIME | 18.7 | NUMBER OF COMPLETED COMMANDS 5 | | CONSOLE 48 | | • | | | | | | TOTAL THINKING TIME | 133.4 | TOTAL RESPONSE TIME | 116.6 | TOTAL SERVICE TIME | 30.0 | NUMBER OF COMPLETED COMMANDS 7 | | | | | | | | | GRAND TOTAL OF RESPONSE TIMES 4502 GRAND TOTAL OF SERVICE TIMES 1403 PERFORMANCE MEASURE 3.21 FRACTION USEFUL PROCESSOR UTILIZATION 0.935 NUMBER OF CHANCES OF DOMAIN # SIMULATION OF NETWORK WITH 9 SITES AND WITH 54 CONSOLES | ************************************** | |----------------------------------------------------------------------------------------| | *************************************** | | START OF RUN NUMBER OF CONSOLES IN THINKING STATE 41 NUMBER AWAITING ENTRY TO SYSTEM 0 | | END OF RUN NUMBER OF CONSOLES IN THINKING STATE 36 NUMBER AWAITING ENTRY TO SYSTEM 0 | | UTILIZATION OF PROCESSORS | | SITE 1 | | TOTAL IDLE TIME 60.8 AVERAGE MEMORY USE 71696 MAXIMUM 121965 | | SITE 2 TOTAL IDLE TIME 41.6 AVERAGE MEMORY USE 65136 MAXIMUM 126458 | | TOTAL IDLE TIME 41.6 AVERAGE MEMORY USE 65136 MAXIMUM 126458 SITE 3 | | TOTAL IDLE TIME 23.8 AVERAGE MEMORY USE 71719 MAXIMUM 115889 | | SITE 4 | | TOTAL IDLE TIME 46.8 AVERAGE MEMORY USE 62161 MAXIMUM 112435 | | SITE 5 | | TOTAL IDLE TIME 46.7 AVERAGE MEMORY USE 62969 MAXIMUM 112889 SITE 6 | | TOTAL IDLE TIME 20.7 AVERAGE MEMORY USE 70847 MAXIMUM 120689 | | SITE 7 | | TOTAL IDLE TIME 40.0 AVERAGE MEMORY USE 66601 MAXIMUM 119485 | | SITE 8 | | TOTAL IDLE TIME 42.8 AVERAĢE MEMORY USE 68012 MAXIMUM 123993<br>SITE 9 | | TOTAL IDLE TIME 18.3 AVERAGE MEMORY USE 68560 MAXIMUM 108749 | | | 11139 NUMBER OF TRANSFERED DOMAINS 69 NUMBER OF TRANSFERED PROCESSORS 7626 NUMBER OF TRANSFERED LOCAL SEGMENTS 6768 NUMBER OF FORCED MIGRATIONS 2999 NUMBER OF PROCESSORS BLOCKED ON ENTRY TO NETWORK O NUMBER OF INCARNATIONS BLOCKED WAITING FOR SPACE O RESPONSE TIMES NUMBER OF COMPLETED SHORT COMMAN'DS 211 NUMBER OF RESPONSE TIMES OVER 2 SECS 0 NUMBER OF RESPONSE TIMES OVER 5 SECS ( REGRESSION ANALYSIS OF NON TRIVIAL SERVICE TIMES VERSUS RESPONSE TIME NUMBER OF DATA POINTS 65 MEAN OF NON TRIVIAL SERVICE TIMES 17.2 MEAN OF RESPONSE TIME 39.6 RESIDUAL STANDARD DEVIATION 9.19 ESTIMATE OF REGRESSION COEFFICIENT 2.26 INTERCEPT 0.70 STANDARD DEVIATION OF REGRESSION COEFFICIENT 0.07 CORRELATION COEFFICIENT 0.975 | | COMMUNICATIONS SUBS | SYSTEM | | | | | | | | | | | | |---|---------------------------|-------------|-------|-----------|-----------------------------------------|------------|------------|----------------------------------------|---------|------------|--------------|-----------|----| | | · NUMBER OF BYTES | TRANSI | FERED | 66558763 | NUMBER OF | CONTROL MI | ESSAGES (3 | 2 BYTES) S | SENT 38 | 3987 | | | | | | DISK PERFORMANCE | | • | | | | | | | | | _ | | | | NUMBER OF BYTES | TRANSI | FERED | 13383539 | NUMBER OF | COMPLETED | TRANSFERS | 1910 | TOTAL | DISK IDLE | TIME 123.8 | 3 | | | | DISK PERFORMANCE | | | | | | | | | | | | | | | NUMBER OF BYTES | TRANSI | FERED | 14095901 | NUMBER OF | COMPLETED | TRANSFERS | 1915 | TOTAL | DISK IDLE | TIME 122.3 | 3 | | | | DISK PERFORMANCE | | | | | | , | | mom . I | n | m=1/6 ( | | | | | NUMBER OF BYTES | TRANSI | FERED | 10538990 | NUMBER OF | COMPLETED | TRANSFERS | 1447 | TOTAL | DISK IDLE | TIME 146.8 | 5 | | | | CONSOLE 1 | TO TE LA CO | 215 6 | TOTAL DEC | SPONSE TIME | 6.6 | TOTAL CED | VICE TIME | 4.9 | NUMBER OF | COMPLETED | COMMANDS | 5 | | | TOTAL THINKING | LIME | 213.0 | TOTAL RES | SPUNSE TIME | 0.0 | TOTAL SER | VICE TIME | 4.9 | NUMBER OF | COMPLETED | COMMANDS | , | | | CONSOLE 2 TOTAL THINKING | TIME | 184 4 | TOTAL DES | SPONSE TIME | 37.9 | TOTAL SER | VICE TIME | 17.6 | NUMBER OF | COMPLETED | COMMANDS | 6 | | | CONSOLE 3 | LIME | 104.4 | TOTAL KEC | HONSE TIME | 37.5 | TOTAL DEK | VIOL IIIID | 17.0 | | COIN BEIED | COLLEGE | Ū | | | TOTAL THINKING | TIME | 28.6 | TOTAL RES | PONSE TIME | 193.6 | TOTAL SER | VICE TIME | 73.8 | NUMBER OF | COMPLETED | COMMANDS | 2 | | | CONSOLE 4 | | | | | | | | | | | | _ | | | TOTAL THINKING | TIME | 128.5 | TOTAL RES | SPONSE TIME | 93.7 | TOTAL SER | VICE TIME | 33.2 | NUMBER OF | COMPLETED | COMMANDS | 4 | | | CONSOLE 5 | | | | | | | | | | | | | | | TOTAL THINKING | TIME | 185.9 | TOTAL RES | SPONSE TIME | 36.4 | TOTAL SER | VICE TIME | 18.3 | NUMBER OF | COMPLETED | COMMANDS | 11 | | | CONSOLE 6 | | | | | | | | | | | | | | | TOTAL THINKING | TIME | 113.9 | TOTAL RES | SPONSE TIME | 108.3 | TOTAL SER | VICE TIME | 38.8 | NUMBER OF | COMPLETED | COMMANDS | 5 | | | CONSOLE 7 | | | | | | | | | | | | | | • | TOTAL THINKING | TIME | 159.6 | TOTAL RES | SPONSE TIME | 62.6 | TOTAL SER | VICE TIME | 31.6 | NUMBER OF | COMPLETED | COMMANDS | 6 | | | CONSOLE 8 | | | | | 04.0 | mom.: 6 an | | | | | | , | | | TOTAL THINKING | TIME | 195.4 | TOTAL RES | SPONSE TIME | 26.8 | TOTAL SER | VICE TIME | 9.0 | NUMBER OF | COMPLETED | COMMANDS | 6 | | | CONSOLE 9 | TIME | 222 0 | TOTAL DEC | SPONSE TIME | 0.3 | TOTAL SER | UTCE TIME | 0.2 | MIIMPED OF | COMPLETED | COMMANDS | 4 | | | TOTAL THINKING CONSOLE 10 | TITE | 222.0 | TOTAL RES | SPUNSE TIME | 0.3 | TOTAL SEK | VICE IIME | 0.2 | NUPIBER OF | COMPLETED | COMMANDS | 4 | | | TOTAL THINKING | TIME | 215.9 | TOTAL RES | SPONSE TIME | 6.3 | TOTAL SER | VICE TIME | 2.9 | NUMBER OF | COMPLETED | COMMANDS | ġ | | | CONSOLE 11 | 1 1,111 | 21717 | TOTAL REC | ,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, | J. J | TOTAL DIR | ,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, | | | 00.11 111111 | COLUMNICA | , | | | · TOTAL THINKING | TIME | 220.3 | TOTAL RES | PONSE TIME | 2,0 | TOTAL SER | VICE TIME | 0.5 | NUMBER OF | COMPLETED | COMMANDS | .7 | | | CONSOLE 12 | | | | | | | | ,,, | | | | • | | | • | | | | | | | | | | | | | | : | | | | | | | | | |-----|--------------------------------|-------|---------------------|-------|--------------------|-------|------------------------------|-----| | į | | | | | | | | | | | TOTAL THINKING TIME CONSOLE 13 | 33.6 | TOTAL RESPONSE TIME | 188.7 | TOTAL SERVICE TIME | 102.2 | NUMBER OF COMPLETED COMMANDS | 3 | | ÷ | TOTAL THINKING TIME CONSOLE 14 | 155.4 | TOTAL RESPONSE TIME | 66.9 | TOTAL SERVICE TIME | 30.6 | NUMBER OF COMPLETED COMMANDS | 9 | | | TOTAL THINKING TIME CONSOLE 15 | 82.8 | TOTAL RESPONSE TIME | 139.4 | TOTAL SERVICE TIME | 50.4 | NUMBER OF COMPLETED COMMANDS | 2 | | | TOTAL THINKING TIME CONSOLE 16 | 196.8 | TOTAL RESPONSE TIME | 25.4 | TOTAL SERVICE TIME | 11.9 | NUMBER OF COMPLETED COMMANDS | 9 | | | TOTAL THINKING TIME CONSOLE 17 | 147.2 | TOTAL RESPONSE TIME | 75.0 | TOTAL SERVICE TIME | 27.2 | NUMBER OF COMPLETED COMMANDS | 6 . | | | TOTAL THINKING TIME CONSOLE 18 | 212.8 | TOTAL RESPONSE TIME | 9.4 | TOTAL SERVICE TIME | 4.4 | NUMBER OF COMPLETED COMMANDS | 7 | | | TOTAL THINKING TIME CONSOLE 19 | 214.4 | TOTAL RESPONSE TIME | 7.9 | TOTAL SERVICE TIME | 4.7 | NUMBER OF COMPLETED COMMANDS | 5 | | | TOTAL THINKING TIME CONSOLE 20 | 64.5 | TOTAL RESPONSE TIME | 157.7 | TOTAL SERVICE TIME | 63.6 | NUMBER OF COMPLETED COMMANDS | 4 | | | TOTAL THINKING TIME CONSOLE 21 | 204.4 | TOTAL RESPONSE TIME | 17.9 | TOTAL SERVICE TIME | 7.6 | NUMBER OF COMPLETED COMMANDS | 4 | | • | TOTAL THINKING TIME CONSOLE 22 | 201.6 | TOTAL RESPONSE TIME | 20.7 | TOTAL SERVICE TIME | 9.0 | NUMBER OF COMPLETED COMMANDS | . 7 | | A-9 | TOTAL THINKING TIME CONSOLE 23 | 86.1 | TOTAL RESPONSE TIME | 136.1 | TOTAL SERVICE TIME | 56.8 | NUMBER OF COMPLETED COMMANDS | 4 | | 4 | TOTAL THINKING TIME CONSOLE 24 | 221.9 | TOTAL RESPONSE TIME | 0.3 | TOTAL SERVICE TIME | 0.2 | NUMBER OF COMPLETED COMMANDS | . 2 | | - | TOTAL THINKING TIME CONSOLE 25 | 222.0 | TOTAL RESPONSE TIME | 0.2 | TOTAL SERVICE TIME | 0.2 | NUMBER OF COMPLETED COMMANDS | 3 | | | TOTAL THINKING TIME CONSOLE 26 | 220.6 | TOTAL RESPONSE TIME | 1.6 | TOTAL SERVICE TIME | o.7 | NUMBER OF COMPLETED COMMANDS | 7 | | | TOTAL THINKING TIME CONSOLE 27 | 7.7 | TOTAL RESPONSE TIME | 214.5 | TOTAL SERVICE TIME | 77.3 | NUMBER OF COMPLETED COMMANDS | 0 | | | TOTAL THINKING TIME CONSOLE 28 | 0.0 | TOTAL RESPONSE TIME | 222,2 | TOTAL SERVICE TIME | 79.5 | NUMBER OF COMPLETED COMMANDS | 0 . | | • | TOTAL THINKING TIME CONSOLE 29 | 216.8 | TOTAL RESPONSE TIME | 5.4 | TOTAL SERVICE TIME | 2.9 | NUMBER OF COMPLETED COMMANDS | 9 | | • | TOTAL THINKING TIME CONSOLE 30 | 99.1 | TOTAL RESPONSE TIME | 123.1 | TOTAL SERVICE TIME | 48.6 | NUMBER OF COMPLETED COMMANDS | 5 | | | TOTAL THINKING TIME CONSOLE 31 | 178.7 | TOTAL RESPONSE TIME | 43.5 | TOTAL SERVICE TIME | 16.2 | NUMBER OF COMPLETED COMMANDS | 6 | | . 4 | TOTAL THINKING TIME CONSOLE 32 | 160.1 | TOTAL RESPONSE TIME | 62.2 | TOTAL SERVICE TIME | 24.3 | NUMBER OF COMPLETED COMMANDS | 3 | | | TOTAL THINKING TIME | 220.4 | TOTAL RESPONSE TIME | 1.8 | TOTAL SERVICE TIME | 1.0 | NUMBER OF COMPLETED COMMANDS | 8 | | CONSOLE 33 | | | | | | | | |--------------------------------|-------------------|-----------------------|--------|--------------------|-------|----------------------------------|----| | TOTAL THINKING TIME | 168.8 | TOTAL RESPONSE TIME | 53.4 | TOTAL SERVICE TIME | 26.9 | NUMBER OF COMPLETED COMMANDS | 6 | | CONSOLE 34 | | | | | | | | | TOTAL THINKING TIME | 216.8 | TOTAL RESPONSE TIME | 5.4 | TOTAL SERVICE TIME | 2.3 | NUMBER OF COMPLETED COMMANDS | 6 | | CONSOLE 35 | | | | | | | | | TOTAL THINKING TIME | 210.9 | TOTAL RESPONSE TIME | 11.4 | TOTAL SERVICE TIME | 5.6 | NUMBER OF COMPLETED COMMANDS | 4 | | CONSOLE 36 | | | | mom | , - | WILLDED OF CONDITION CONVINCE | 0 | | TOTAL THINKING TIME | 209.4 | TOTAL RESPONSE TIME | 12.8 | TOTAL SERVICE TIME | 4.5 | NUMBER OF COMPLETED COMMANDS | 8 | | CONSOLE 37 | <i>(</i> <b>7</b> | TOTAL DECRONCE TIME | 15/. / | TOTAL CEDUTCE TIME | 40 5 | NUMBER OF COMPLETED COMMANDS | 2 | | TOTAL THINKING TIME | 67.8 | TOTAL RESPONSE TIME | 134.4 | TOTAL SERVICE TIME | 00.5 | NORIDER OF CONFESTED CONMANDS | 2 | | CONSOLE 38 TOTAL THINKING TIME | 67.0 | TOTAL RESPONSE TIME | 155 2 | TOTAL SERVICE TIME | 62.8 | NUMBER OF COMPLETED COMMANDS | 1 | | CONSOLE 39 | 67.0 | TOTAL RESPONSE TIME | 100.0 | TOTAL SERVICE TIME | 02.0 | NOTIBER OF COLL LETED COLLIENDS | - | | TOTAL THINKING TIME | 118.9 | TOTAL RESPONSE TIME | 103.3 | TOTAL SERVICE TIME | 55.1 | NUMBER OF COMPLETED COMMANDS | 5 | | CONSOLE 40 | 110.5 | TOTAL RESTORGE TIME | 103.3 | TOTAL BERVIOL TIME | 33.1 | NOTIFIER OF COLD EDITION COLDERS | • | | TOTAL THINKING TIME | 164.9 | TOTAL RESPONSE TIME | 57.3 | TOTAL SERVICE TIME | 18.3 | NUMBER OF COMPLETED COMMANDS | 4 | | CONSOLE 41 | 20443 | TOTAL RESIDENCE TARRE | 3,10 | | | | • | | TOTAL THINKING TIME | 210.8 | TOTAL RESPONSE TIME | 11.4 | TOTAL SERVICE TIME | 5.6 | NUMBER OF COMPLETED COMMANDS | 5 | | CONSOLE 42 | | | | | | | | | TOTAL THINKING TIME | 70.4 | TOTAL RESPONSE TIME | 151.8 | TOTAL SERVICE TIME | 66.1 | NUMBER OF COMPLETED COMMANDS | 4 | | CONSOLE 43 | | | | | | | | | TOTAL THINKING TIME | 110.9 | TOTAL RESPONSE TIME | 111.3 | TOTAL SERVICE TIME | 48.6 | NUMBER OF COMPLETED COMMANDS | 2 | | CONSOLE 44 | | · | | | | | | | TOTAL THINKING TIME | 21.1 | TOTAL RESPONSE TIME | 201.1 | TOTAL SERVICE TIME | 111.3 | NUMBER OF COMPLETED COMMANDS | 0 | | CONSOLE 45 | | | | | | | | | TOTAL THINKING TIME | 144.6 | TOTAL RESPONSE TIME | 77.7 | TOTAL SERVICE TIME | 31.8 | NUMBER OF COMPLETED COMMANDS | 10 | | CONSOLE 46 | | | | | | | | | TOTAL THINKING TIME | 51.1 | TOTAL RESPONSE TIME | 171.1 | TOTAL SERVICE TIME | 65.8 | NUMBER OF COMPLETED COMMANDS | 1 | | CONSOLE 47 | 104.0 | mamus proposed mayor | 25 / | MODAL GENUTGE MINE | 10 / | WINDER OF COMPLETED COMMING | _ | | TOTAL THINKING TIME | 186.8 | TOTAL RESPONSE TIME | 35.4 | TOTAL SERVICE TIME | 12.4 | NUMBER OF COMPLETED COMMANDS | 5 | | CONSOLE 48 TOTAL THINKING TIME | 1.45 1 | TOTAL RESPONSE TIME | 77.1 | TOTAL SERVICE TIME | 30.1 | NUMBER OF COMPLETED COMMANDS | 7 | | CONSOLE 49 | 143.1 | TOTAL RESPONSE TIME | // • 1 | TOTAL SERVICE TIME | 30.1 | NOTIBER OF CONFESTED CONFESTOR | ′ | | TOTAL THINKING TIME | 34.9 | TOTAL RESPONSE TIME | 187.3 | TOTAL SERVICE TIME | 100.8 | NUMBER OF COMPLETED COMMANDS | 0 | | CONSOLE 50 | 34.7 | TOTAL KIND ONOU TIME | 107.5 | TOTAL BERVIOL TIME | 10010 | NOTIFIER OF COLUMNIES | U | | TOTAL THINKING TIME | 221.5 | TOTAL RESPONSE TIME | 0.7 | TOTAL SERVICE TIME | 0.6 | NUMBER OF COMPLETED COMMANDS | 7 | | CONSOLE 51 | | , | 0 | | 0.0 | | • | | | 168.5 | TOTAL RESPONSE TIME | 53.7 | TOTAL SERVICE TIME | 23.6 | NUMBER OF COMPLETED COMMANDS | 6 | | CONSOLE 52 | • | | | • | • | | | | TOTAL THINKING TIME | 216.9 | TOTAL RESPONSE, TIME | 5.3 | TOTAL SERVICE TIME | 3.2 | NUMBER OF COMPLETED COMMANDS | 6 | | CONSOLE 53 | | | | | | | | | | | | | | | | | TOTAL THINKING TIME 190.6 TOTAL RESPONSE TIME 31.6 TOTAL SERVICE TIME 15.4 NUMBER OF COMPLETED COMMANDS 11 CONSOLE 54 TOTAL THINKING TIME 151.6 TOTAL RESPONSE TIME 70.6 TOTAL SERVICE TIME 23.6 NUMBER OF COMPLETED COMMANDS 8 GRAND TOTAL OF RESPONSE TIMES 3834 GRAND TOTAL OF SERVICE TIMES 1633 PERFORMANCE MEASURE 2.35 FRACTION USEFUL PROCESSOR UTILIZATION 0.817 A-96 ## BIBLIOGRAPHY - ABRA70 ABRAMSUN N. 'The ALOHA system another alternative for computer communications' AFIPS FJCC vol 37 1970 pp 281-285 - ADAMS C.A. 'Grosch's law repealed' Datamation Vol 8 No 7 Jul 1962 pp 38-39. - ADAMS J.C. & MILLARD G.E. 'Performance measurements on the Edinburgh multi-access system' EMAS Report 7, Dept of Computer Science Univ. of Edinburgh 1975 14pp. - ADAMS C. 'Over the horizon: a report on the June 1975 computer elements technical committee workshop' Computer Vol 9 No 2 Feb 1976 pp 8=11. - AGRA75 AGRAWALA A.K. & BRYANT R.M. 'Models of memory scheduling' Proc 5th Symp. on U.S. principles (Texas) SIGOPS Vol 9 No 5 Nov 1975 pp 217-222. - AGRA76 AGRAWALA A.K., MOHR J.M. & BRYANT R.M 'An approach to the workload characterisation problem' Computer Vol 9 No 6 Jun 1976 pp 18-32. - AISO75 AISO H. et al. 'A minicomputer complex KOCOS' Proc 4th Data Communications Symp. (Quebec) IEEE Catalogue 75 CH1001-7DATA, Oct 1975 pp 5\_7-5\_12. - AKKO72 AKKOYUNLU E. et al. "An operating system for a network environment" Proc. Symp. on Computer Communications Networks and Teletraffic (Brooklyn) Apr 1972 pp 529-538. - AKKO74 AKKOYUNLU E. et al. "Interprocess communication facilities for network operating systems" Computer Vol 7 No 6 Jun 1974 pp 46-55. - AKKO75 AKKOYUNLU E.A. et al. 'Some constraints and tradeoffs in the design of network communications' Proc. 5th Symp. on O.S. Principles (Texas) Nov 1975 pp 67-74. - AMDA67 AMDAHL G.M. 'Validity of the single processor approach to achieving large scale computing capabilities' AFIPS SJCC Vol 30 1967 pp 483-485. - ANDERSUN G.A & JENSEN E.D. 'Computer interconnection structures: taxonomy, characteristics and examples' Computing Surveys Vol 7 No 4 Dec 1975 pp 197-213. - ARDE75 ARDEN B.N. & BERENBAUM A.D. "A multi-microprocessor computer system architecture" Proc. 5th Symp. on U.S. principles (Texas) SIGUPS Vol 9 No 5, Nov 1975 pp 114-121. - ATTA76 ATTANASIU C.R., MARKSTEIN P.M.& PHILLIPS R.J. 'Penetrating an operating system: a study of VM/370 integrety' IBM Systems Journal Vol 15 No 1 1976 pp 102-116. - BALZAR R.M. 'Ports = a method for dynamic interprogram communication and job control' AFIPS SJCC Vol 38 1971 pp 485-489. - BASK76 BASKETT F. & SMITH A.J. 'Interference in multiprocessor computer systems with interleaved memory' CACM Vol 19 No 6, Jun 1976 pp 327-334. - BASKIN H.B., BURGERSUN B.R. and ROBERTS R. 'PRIME A modular architecture for terminal orientated systems' Proc AFIPS SJCC Vol 40 1972 pp 431-437. - BATS76 BATSON A.P., BRUNDAGE R.E. & KEARNS J.P. "Design data for ALGOL 60 machines" Proc 3rd Annual Symp. on Computer Architecture, as SIGARCH Vol 4 No 4 Jan 1976 pp 151-154. - BELL70 BELL C.G. et al. 'Computer Networks' Computer Vol 9 No 5 Sept/Uct 1970. pp 13=23 - BERN73 BERNARD D. 'Intercomputer networks an overview and bibliography' Masters Thesis Pennsylvania Univ. May 1973 as Microfiche AD-769 232. - BHAN73a BHANDARKAR D.P. 'Analytic models for memory interference in multiprocessor computer systems' Ph.D. Thesis Computer Science Dept. Carnegie=Mellon Univ. Sept 73. - BHAN73b BHANDARKAR D.P. & FULLER S.H. 'Markov chain models for analysing memory interference in multiprocessor computer systems' Proc. 1st Annual Symp. on Computer Architecture (Florida) Dec 1973 pp 1-6. - BIND75 BINDER R. et al. "ALOHA packet broadcasting = a retrospect" AFIPS NCC Vol 44 1975 pp 203-215. - BLAK75 BLAKESLEE T.R. 'Digital Design with Standard MSI & LSI' John Wiley and Son (New York) 1975. - BLAN73 BLANC R.P. et al. 'Annotated Bioliography of the Literature on Resource Sharing Computer Networks' National Bureau of Standards NBS Special Publication 384, 1973. - BORG76 BORGERSON B.R. 'The viability of multimicroprocessor systems' Computer Jan 1976 pp 26-30. - BURN73 BURNET S.J. & COFFMAN E.G. 'Combinatorial problem related to interleaved memory systems' JACM Vol 20 No 1 1973 pp 39-45. - BURR61 BURROUGHS CORP. The descriptor a definition of the B5000 information processing system. The Burroughs Corp. (Detroit) No 5000-20002-P, Feb 1961. - BUZE73 BUZEN J.P. & GAGLIARDI U.O. The evolution of virtual machine architecture AFIPS NCC Vol 42 1973 pp 291-299. - CARR75 CARREN D.M. 'Multiple minis for information management' Datamation Vol 21 No 9 Sept 1975 pp 54-58. - CHOU75 CHOU W. 'Computer communication networks the parts make up the whole' AFIPS NCC Vol 44 1975 op 119-128. - CODD62 CODD E.F. 'Multiprogramming' in ALT F.L & RUBINOFF M. (eds) 'Advances in Computers' Vol 3 Academic Press (New York) 1962 pp 77-153. - COHE75 COHEN E. & JEFFERSON D. 'Protection in the HYDRA operating system' Proc. 5th Symp. O.S. Principles (Texas) Nov 1975 pp 141-160. - COLE73 COLEMAN M.L. 'ACCNET a corporate computer network' AFIPS NCC Vol 42 1973 pp 133-140. - COLO76 COLON F.C. ET ALIA. 'Coupling small computers for performance enhancement' AFIPS NCC Vol 45 1976 pp 755-764. - CORBATO F.J., SALTZER J.H. & CLINGEN C.T. 'Multics the first seven years' AFIPS SJCC Vol 40 1972 pp 571-583. - COSE75 CUSELL B.P. et al. "An operational system for computer resource sharing" Proc. 5th Symp. on 0.S. principles (Texas) Nov 1975 pp 75-81. - COSST2 COSSERAT D.C. 'A capability orientated multi-processor system for real-time applications' Proc 1st Int. Conf. on Computer Communication (Washington D.C.) Oct 1972 pp 282-289. - COSS74 COSSERAT D.C. "A data model based on the capability protection mechanism" IRIA International Workshop on Protection in U.S. (Paris) Aug 1974 pp 35-53. - CRAIT 4 CRAIG D. & GROUMS D. 'Computer Networks. A Bibliography with Abstracts' NTIS (Springfield) NTIS/NIN 74 081, Uct 1974 169pp - CURTIN W.A. 'Multiple computer systems' in ALT f.L. & RUBINDFF M. (eds) 'Advances in Computers' Vol 4 Academic Press (New York) 1963 pp 245=303. - DAHL66 DAHL U.J. and NYGAARD K. 'SIMULA an ALGOL-based simulation language' CACM Vol 9 No 9 Sept 1966 pp 671-678. - DAHL72 DAHL O.J., MYHRHAUG B. & NYGAARD K. 'Common Base Language' Norwegian Computer Center (Dslo) Publication No S-22, 1970. - DAVI72 DAVIS R.L., ZUCKER S. & CAMPBELL C.M. "A building block approach to multiprocessing" AFIPS SJCC Vol 40 pp 685-703. - DENN66 DENNIS J.B. & VAN HORN E.C. 'Programming semantics for multiprogrammed computations' CACM Vol 9 No 3 Mar 1966 pp 143-155. - DIJKSTRA E.W. 'The structure of the THE multiprogramming system' CACM Vol 11 No 5 May 1968 pp 341-346. - DIJK71 DIJKSTRA E.W. 'Hierarchical ordering of sequential processes' Acta Informatica Vol 1 No 2 1971 pp 115-138. - DORA75 DORAN R.W. 'Architecture of stack machines' in CHU Y. (Ed) 'High-level Language Computer Architecture' Academic Press (New York) 1975 pp 63-108. - DUVATS DUVALL W.S. 'PDGOS An Operating System for a Network of Small Machines' Private Communication 1975. - ELRU70 ELRUD T.H. 'The CDC 7600 and SCOPE 76' Datamation Vol 16 No 4 April 1970 pp 80-85. - ENGL72 ENGLAND D.M. 'Architectural features of system 250' Infotech State of the Art Report 14; Operating Systems, 1972. - ENGL74 ENGLAND D.M. 'Capability concept mechanism and structure in system 250' IRIA International Norkshop on Protection in O.S. (Paris) Aug 1974 pp 63-82. - ESTR67 ESTRIN G. & KLEINRUCK L. 'Measures, models and measurements for time-shared computer utilities' Proc. 22nd Nat. Conf. of ACM 1967 pp 85-96. - EVANS D.C. & LECLERC J.Y. Address mapping and the control of access in an interactive computer AFIPS SJCC Vol 30 1967 pp 23=30. - FABR73 FABRY R.S. 'Dynamic verification of operating system decisions' CACM Vol 16 No 11 Nov 1973 pp 659-688. - FABR74 FABRY R.S. 'Capability-based addressing' CACM Vol 17 No 7 Jul 1974 pp 403-412. - FARB72 a FARBER D.J. et al. "The distributed computer system" Compcon 72 Proc. 7th Int. Computer Soc. Conf. 1972 pp 31-34. - FARB72 b FARBER D.J. and HEINRICH F.R. "The structure of the distributed computer system the distributed file system" Proc 1st Int. Conf. on Computer Communication (Washington) Oct 1972 pp 364-370. - FARB72 c FARBER D.J. & LARSON K.C. 'The system architecture of the distributed computer system the communications system' Symp. Computer-Communications Networks and Teletraffic (New York) Apr 1972 pp 21-27. - FARB72 d FARBER D.J. & LARSON K.C 'The structure of a distributed computing system = software' Proc. Symp. Computer-Communications Networks and Teletraffic (New York) Apr 1972 pp 539-545. - FARBT4 FARBER D.J. 'Software considerations in distributed architectures' Computer Vol 7 No 3 Mar 1974 pp 31-35 - FARB75 FARBER D.J. 'A ring network' Datamation Vol 21 No 2 Feb 1975 pp 44-46. - FERR74 FERRIE J. et alia. "An extensible structure for protected systems design" IRIA International Workshop on Protection in Operating Systems (Paris) Aug 1974 pp 83-105. - FEUS73 FEUSTAL E.A. 'On the advantages of tagged architectures' IEEE Trans. on Computers Vol C-22 No 7 July 1973 pp 644-656. - FLYN72 FLYNN M.J. 'Some computer organizations and their effectiveness' IEEE Irans. on Computers Vol C-21 No 9, Sept 1972 pp 948-960. - FUST72 FOSTER C.C. 'A view of computer architecture' CACM vol 15 No 7 Jul 1972 pp 557-565. - FRANT2 FRANK H., KAHN R. & KLEINRUCK L. 'Computer communication network design = experience with theory and practice' AFIPS SJCC Vol 40 1972 pp 255-270. - FRED73 FREDERICKSEN D.H. Describing data in computer networks' IBM Systems Journal Vol 3 No 3 1973 pp 257-282. - FUCHEL K. & HELLER S. "Considerations in the design of a multiple computer system with extended core storage" CACM Vol 11 No 5 May 1968 pp 334-340. - FULL76 FULLER S.H. 'Price/performance comparison of C.mmp and the PDP=10' Proc 3rd Annual Symp. on Computer Architecture, as SIGARCH Vol 4 No 4, Jan 1976 pp 195-202. - GECC75 GEC COMPUTERS LIMITED 'GEC 4080 Technical Description' (Borehamwood England WD6 1RX) June 1975. - GHEZZI C. et al. 'Introduction to POLI computer network design' Proc ACM Int. Computing Symp. (Davos) 1973 pp 271-278. - GOLD73 GOLDBERG R.P. 'Architecture of virtual machines' AFIPS NCC Vol 42 1973 pp 309=318. - GOLD74 GOLDBERG R.P. & HASSINGER R. 'The double paging anomaly' AFIPS NCC Vol 43 1974 pp 195-199. - GOOD/IN R.J. 'A Design for a Distributed Control Multiple-Processor Computer System' Masters thesis: Naval Postgraduate School (Monterey, Calif.) as Microfiche AD 722 883, 1973 42pp - GRAHAM G.S. & DENNING P.J. 'Protection principles and practice' AFIPS SJCC Vol 40 1972 pp 417-429. - GRAHAM R.M. 'Protection in an information processing utility' CACM Vol 11 No 5 1968 pp 365-369. - GROSS3 GROSCH H.R.J. 'High speed arithmetic: the digital computer as a research tool' Journal of the Optical Society of America Vol 43 No 4 Apr 1953 pp 306-310. - GROS76 GROSCH H.R.J. 'Distributed intelligence' Computer World Vol 10 No 23 June 7th 1976. - HANS70 HANSEN P.8. The nucleus of a multiprogramming system CACM Vol 13 No 4 Apr 1970 pp 238-241 and p 250. - HANS73 HANSEN P.B. 'Operating System Principles' Prentice-Hall (Englewood Cliffs) 1973. - HANS74 HANSEN P.B. "A program methodology for operating system design" IFIP Congress (Stockholm) 1974 pp 394-397. - HANS75 HANSEN P.B. 'The programming language Concurrent Pascal' IEEE Trans. on Software Engineering Vol SE-1 No 2 June 1975 pp 199-207. - HANS76 HANSEN P.B. ""The SOLO papers" Software Practice and Experience Vol 6 No 2 1976 pp 139-205. - HAYN73 HAYNES J. 'Please don't interrupt me while I'm computing!' Computer Vol 6 no 12 Dec 1973 pp 45-47. - HEAR73 HEART F.E. et al. "A new minicomputer/multiprocessor for the ARPA network" AFIPS NCC Vol 42 1973 pp 529-537. - HICK71 HICKEN G.M. 'Experience with an information network' Digest Proc. IEEE Conf. on Hardware Software Firmware Trade-offs (Boston) Sep 1971 pp 169-170. - HIGB73 HIGBIE L.C. 'Supercomputer architecture' Computer Vol 6 No 12 Dec 1973 pp 48-58. - HIRC74 HIRCH P. 'SITA: rating a packet switched network' Datamation Mar 1974 pp 60-63. - HOAR73 HOARE C.A.R. 'A structured paging system' Computer Journal Vol 16 No 3 1973 pp 209-215. - HOAR74 a HOARE C.A.R. 'Monitors: an operating system structuring concept' CACM Vol 17 No 10 Oct 1974 pp 549-557. - HUAR74 b HUARE C.A.R. "A structured operating system" Presented at SRC Summer School on Computer Architecture and Operating Systems (Cambridge) Sep 1974. - HOLB75 HOLBAEK-HANSSEN E., HANDLYKKEN P. & NYGAARD K. "System Description and the DELTA Language" DELTA Project Report No 4, Norwegian Computing Center (Oslo) 1975. - HOWE72 HOWELL R.H. 'The integrated computer network system' Proc 1st Int. Conf. on Computer Communication (Mashington) Oct 72 pp 214-219. - HUTC68 HUTCHINSON G.K. 'Some problems in the simulation of multiprocessor systems' in BUXTON J.N. (Ed) 'Simulation Programming Languages' North-Holland (Amsterdam) 1968 pp 305-324. - ICHB74 ICHBIAH J.D & MURSE S.P. 'General concepts of the SIMULA 67 programming language' in HALPER et al. (Eds) 'Annual Review in Automatic Programming' Pergamon Press (Oxford) 1974 pp 65-93. - JAGE74 JAGERSTROM J. "A multi mini system" Proc. European Computing Congress May 1974 pp 717-725. - JONE71 JONES P.D., LINCOLN N.R. & THORNION J.E. 'Whither computer architecture' IFIP Congress (Ljubljana) 1971 pp 729-736. - JOSEPH E.C. Innovation in heterogeneous and homogeneous distributed function architectures Computer Vol 7 No 3 Mar 1974 pp 17-24. - KAUB76 KUBISCH W.H., PERROT R.H. & HOARE C.A.R. "Quasiparallel programming" Software Practice and Experience Vol 6 No 3 1976 pp 341-356. - KIMB75 KIMBLETON S.R. & SCHNEIDER G.M. 'Computer communication networks: approaches, objectives and performance considerations' Computing Surveys Vol 7 No 3 Sep 1975 pp 129-173. - KLEI68 KLEINRUCK L. 'Certain analytic results for time-shared processors' IFIP Congress (Edinburgh) 1968 pp 838-845. - KLEI70 KLEINRUCK L. 'Analytic and simulation methods in computer network design' AFIPS SJCC Vol 36 1970 pp 569-579. - KLEI74 KLEINROCK L. Resource allocation in computer systems and computer-communication networks' IFIP Congress (Stockholm) 1974 pp 11-18. - KLEI75 KLEINROCK L. 'Queueing Systems Volume 1: Theory' John Wiley (New York) 1975. - KLEINRUCK L. "Queueing Systems Volume 2: Computer Applications" John Wiley (New York) 1976. - KNIG66 KNIGHT K.E. 'Changes in computer performance' Datamation Vol 12 No 9 Sep 1966 pp 40-54. - KNOT74 KNOTT G.D. 'A proposal for certain process management and intercommunication primitives' SIGDPS Vol 8 No 4 Oct 1974 pp 7-44, continued in Vol 9 No 1 Jan 1975 pp 20-41. - LAMPSON B.W. 'Protection' Proc. 5th Princeton Conf. on Information Sciences and Systems, Mar 1971 pp 437-443, reprinted in SIGOPS Vol 8 No 1 Jan 1974 pp 18-24. - LAMPSON B.N. Redundancy and robustness in memory protection' IFIP Congress (Stockholm) 1974 pp 128-132. - LAMPSON B.W. & STURGIS H.E. 'Reflections on an operating system design' CACM Vol 19 No 5 May 1976 pp 251-265. - LAYM74 LAY W.M., MILLS D.L. and ZELKONIIZ M.V. "Operating systems architecture for a distributed computer network" Computer Networks: Conf. IEEE Computer Soc. and NBS, (Gaithersburg) May 1974 pp 39-44. - LEEA66 LEE A.M. 'Applied Queueing Theory' Studies in Management Series, Macmillan (London) 1966. - LEINER A.L. et alia 'PILOT, the NBS multicomputer system' Proc. Eastern Joint Computer Conf. (Philadelphia) 1958 pp 71-75. - LEVI75 LEVIN R. et alia 'Policy/mechanism separation in HYDRA' Proc 5th Symp. on O.S. Principles (Texas) Nov 1975 pp 132-140. - LIND71 LINDSAY P.J. 'A simple asynchronous interface for linking small computers' Proc DECUS Conf. 1971 pp 253-256. - LISTTR A.M. & MAYNARD K.J. "An implementation of monitors" Software Practice and Experience Vol 6 No 3 1976. pp 377-385. - MADNICK S.E. 'Multi-processor software lockout' Proc 23rd National Conf. ACM 1968 pp 19-24. - MADS72 MADSEN O.B. 'Karoline: a network computer project' RECAU-72-14, University of Aarhus, Denmark 1972. - MANN75 MANNING E. and PEEBLES R.W. Segment transfer protocols for a homogeneous computer network ACM Operating Systems Review Vol 9 No 3 Jul 1975 pp 65-73. - MCQU72 McUUILLAN J.M. et alia. "Improvements in the design and performance of the ARPA network" AFIPS FJCC Vol 41 1972 pp 741-754. - METC72 a METCALFE R.M. 'Strategies for interprocess communication in a distributed computing system' Symp. on Computer-Communications Networks and Teletraffic (Brooklyn) Apr 1972 pp 519-526. - METC72 b METCALFE R.M. "Strategies for operating systems in computer networks" Proc. of 25th Annual Conf. of ACM (Boston) 1972 pp 278-281. - METC76 METCALFE R.M. & BOGGS D.R. 'Ethernet: distributed packet switching for local computer networks' CACM Vol 19 Jul 1976 pp 395-404. - MEYE70 MEYER R.A. & SEAWRIGHT L.H. 'A virtual machine time-sharing system' IBM Systems Journal Vol 9 No 3 1970 pp 199-218. - MILLS D.L. 'An overview of the distributed computer network' AFIPS NCC Vol 45 1976 pp 523-531. - MUDR71 MODRE C. 'Network Model of Time Shared Computer Systems' Ph.D. Thesis Univ. of Michigan (Ann Arbor) Microfiche AD 727 206, 1971. - NEED72 NEEDHAM R.M. 'Protection systems and protection implementations' AFIPS FJCC Vol 41 1972 pp 571-578. - NEED74 NEEDHAM R.M. & WILKES M.V. 'Domains of protection and the management of processes' The Computer Journal Vol 17 No 2 May 1974 pp 117-120. - OPDE75 OPDERBECK H. 'Problems in the design of control procedures for computer networks' ACM Computer Communication Review Vol 5 No 2 Apr 1975 pp 1-7. - ORGA73 URGANICK E.I. 'Computer System Organization -The p5700/B6700 Series' ACM Monograph Series, Academic Press (New York) 1973. - ORNS75 ORNSTEIN S.M. et alia. 'PLURIBUS a reliable multiprocessor' Proc AFIPS NCC Vol 44 1975 pp 551-559. - PARM72 PARMLEE R.P. et alia 'Virtual storage and virtual machine concepts' IBM Systems Journal Vol 11 No 2 1972 pp 99-130. - PARN72 PARNAS D.L. 'On the criteria to be used in decomposing systems into modules' CACM Vol 15 No 12 Dec 1972 pp 1053=1058. - PARN74 a PARNAS D.L. 'On a "buzzword": hierachical structure' IFIP Congress (Stockholm) 1974 pp 336-339. - PARN74 b PARNAS D.L & PRICE W.E. "Using memory access control as the only protection mechanism" IRIA Int. Workshop on Protection in Operating Systems, (Paris) Aug 1974 pp 177-181. - POPE74 POPEK G.J. & KLINE C.S. 'Verifiable secure operating system software' AFIPS NCC Vol 43 1974 op 145-151. - PYKE74 PYKE T.N. Private communication, 1974. - POUZIN L. "Network architectures and components" Proc of 1st European Norkshop on Computer Networks (Arles) Apr 1973 pp 227-266. - REAM76 REAMES C.C. & LIU M.T. 'Design and simulation of the distributed loop computer network (DLCN)' Proc 3rd Annual Symp. on Computer Architecture, as SIGARCH Vol 4 No 4 Jan 1976 pp 124-129. - REDE74 REDELL D.D. 'Naming and Protection in Extensible Operating Systems' Ph.D. Thesis M.I.T., Project MAC Report MAC-TR-140, Nov 1974. - RETZ75 RETZ D.L. 'Operating system design considerations for the packet-switching environment' AFIPS NCC Vol 44 1975 pp 155-160. - REYLING G. 'Performance and control of multiple microprocessor systems' Computer Design Vol 13 No 3 Mar 1974 pp 81-87. - ROBERTS L.G. and WESSLER B.D. 'Computer network development to achieve resource sharing' AFIPS SJCC Vol 36 1970 pp 543-549. - ROWA74 ROWAN J.H., SMITH D.A. & SWENSEN M.D. 'Towards the design of a network manager for a distributed computer network' in FENG I. (Ed) 'Parallel Processing' Lecture Notes in Computer Science No 24, Springer Verlag (Berlin) 1974. - RUWE L.A. et al. 'Software methods for achieving fail-soft behaviour in the distributed computer system' IEEE Symp. on Computer Software Reliability (New York) 1973 pp 7-11. - SALT66 SALTZER J.H. "Traffic control in a multi-plexed computer system" MIT Technical Report MAC-TR-30 Jul 1966. - SALTZAR J.H. "Protection and control of information sharing in Multics" CACM Vol 17 No 7 Jul 1974 pp 388-402. - SCHAFFER H.F. 'Are minicomputers suitable for large scale scientific computations?' 11th IEEE Comp. Soc. Conf., Fall Compcon75 (Washington) Sep 1975 pp 61-64. - SCHE67 SCHERR A.L. "An Analysis of Time-Shared Computer Systems" 4.I.f. Research Monograph No 36, The M.I.T. Press (Massachusetts) 1967. - SCHROEDER M.D. & SALTZAR J.H. 'A hardware architecture for implementing protection rings' CACM Vol 15 No 3 Mar 1972 pp 157-170. - SCOT74 SCUTT C.T. 'An annoted bibliography on computer systems reliability' Infotech State of the Art Report 20, 1974. - SEARTS SEARLE B.C. & FREBERG D.E. 'Microprocessor applications in multiple processor systems' Computer Vol 8 No 10 Oct 1975 pp 22-30. - SELI72 SELIGMAN L. 'LSI and minicomputer system architecture' AFIPS SJCC Vol 40 1972 pp 767-773. - SEVC72 SEVCIK K.C. et alia. 'Project SUE as a learning experience' AFIPS FJCC Vol 41 1972 pp 331-338. - SEVC74 SEVCIK K.C. & TSICHRITZIS D.C. "Authorization and access control within overall system design" IRIA Int. Workshop on Protection in Operating Systems (Paris) Aug 1974 pp 211-224. - SMIT72 SMITH B.T. 'Mixed computer networks: benefits, problems and guidelines' Proc. 1st Int. Conf. on Computer Communication (Nashington) Uct 1972 pp 201-208. - SPIE73 a SPIER M.J. "A model implementation for protective domains" Int. Journal of Computer and Information Sciences Vol 2 No 3 Sep 19/3 pp 201-229. - SPIE73 b SPIER M.J. 'Process communication prerequisites or the IPC-setup revisited' Proc of the 1973 Sagamore Computer Conf. on Parallel Processing, IEEE publication #73 CH0812-8 C Aug 1973 pp 79=88. - SPIE74 SPIER M.J., HASTINGS T.N. and CUTLER D.N. 'A storage mapping technique for the implementation of protective domains' Software Practice and Experience Vol 4 No 3 1974 pp 215-230. - SPOUNER C.R. 'A software architecture for the 70's: part 1 the general approach' Software Practice and Experience Vol 1 No 1 pp 5-37. - STEP74 STEPHENS P.D. 'The IMP language and compiler' The Computer Journal Vol 17 No 3 1974 pp 216-221. - TANG76 TANG C.K. 'Cache system design in the tightly coupled multiprocessor system' AFIPS NCC Vol 45 1976 pp 749-753. - THOMAS R.H. & HENDERSUN D.A. "McROSS a multi-computer programming system" AFIPS SJCC Vol 40 1972 pp 281-293 - THOM73 THOMAS R.H. "A resource sharing executive for the ARPANET" AFIPS NCC Vol 42 19/3 pp 155-163. - THUR75 THURBER K.J. & WALD L.D. "Associative and parallel processors" Computing Surveys Vol 7 No 4 Dec 1975 pp 215-255. - TJADEN G.S. & FLYNN M.J. 'Detection and parallel execution of independent instructions' IEEE Trans. on Computers Vol C19 No 10 Oct 1970 pp 889-895. - TYME71 TYMES L.R. 'TYMNEF A terminal orientated communication network' AFIPS SJCC Vol 38 1971 pp 211-216. - WALD72 WALDEN D.C. "A system for interprocess communication in a resource sharing computer network" CACM Apr 1972 pp 221-230 - WENS75 WENSLY J.H. 'The impact of electronic disks on system architecture' Computer Vol 8 No 8 Feb 1975 pp 44-48. - WHIT73 WHITFIELD H. & WIGHT A.S. "EMAS the Edinburgh Multi-access system" The Computer Journal Vol 16 No 4 1973 pp 331-346. - WIDD76 WIDD0ES L.C.Jr. 'The Minerva multi-processor' Proc 3rd Annual Symp. on Computer Architecture, as SIGARCH Vol 4 No 4 Jan 1976 pp 34-39. - WILK73 WILKES M.V. "The dynamics of paging" The Computer Journal Vol 16 No 1 1973 pp 4-9. - WIRC75 MIRCHING J.E. 'Computer of the 1980's is it a network of microcomputers' Proc Fall Compcom75 (Washington), IEEE publication 75CH0988-6C, Sep 1975 pp 23-26. - WIRT74 WIRTH N. 'On the design of programming languages' IFIP Congress (Stockholm) 1974 pp 386-393. - WITH75 WITHINGTON F.G. "Beyond 1984: a technology forecast" Datamation Vol 21 No 1 Jan 1975 pp 54-73. - WITT68 WITT B.I. 'M65MP: an experiment in US/360 multiprocessing' Proc 23rd Nat. Conf. of ACM 1968 pp 691-703. - WITT76 WITTIE L.D. 'Efficient message routing in mega-micro-computer networks' Proc 3rd Annual Symp. on Computer Architecure, IEEE publication 76CH1043-5C, Jan 1976 pp 136-140. - WULF72 WULF W.A. and BELL C.G. 'C.mmp = a multi-mini-processor' AFIPS FJCC Vol 41 1972 pp 765-777. - WULF74 WULF W.A. et al. "HYDRA: the kernel of a multiprocessor operating system" CACM Vol 17 No 6 Jun 1974 pp 337-345. - WULF75 a WULF W.A. & LEVIN R. 'A local network' Datamation Vol 21 No 2 Feb 1975 pp 47-50. - WULF75 b WULF W.A., LEVIN R. and PIERSON C. "Overview of the HYDRA operating system development" Proc 5th Symp. U.S. Principles (Texas) Nov 1975 pp 122-131. - ZELKOWITZ M.V. 'Structured operating system organization' Information Processing Letters Vol 3 No 2 Nov 1974 pp.