Uillted States Patent [19] [11] Patent Number: 5,379,432 Orton Et Al

Total Page:16

File Type:pdf, Size:1020Kb

Uillted States Patent [19] [11] Patent Number: 5,379,432 Orton Et Al . USOO5379432A UIllted States Patent [19] [11] Patent Number: 5,379,432 Orton et al. [45] Date of Patent: Jan. 3, 1995 [54] OBJECT-ORIENTED INTERFACE FOR A 5,339,422 8/1994 Brender et al. ................... .. 395/700 PROCEDURAL OPERATING SYSTEM 5,341,478 8/1994 Travis, Jr. et a1. ............... .. 395/200 [75] Inventors: Debra L. Orton, San Jose; Eugenie L. OTHER PUBLICATIONS Boltmlr Sunnyvale; Daniel Guedes, Paulo, “Objet-Oriented Interfaces in the Mach chermlioff’ P810 Alto; DaYld B‘ 3.0 Multi-server System”, IEEE 1991. Goldsmlth’ Los Gatos; chnstoPher P‘ Rashid, Richard, “Machi A Foundation For Open Sys . Mwlle's L°S Ah“, 9“ °f Cahf- terns”, Carnegie Mellon University, IEEE 1989. [73] Assignee: Taligent, Inc., Cupertino, Calif. Mary Jo Foley, “Taligent, IBM draw closer”, PC Week, Feb. 21, 1994 vol. 11, No. 7 p. 8. [21] Appl‘ No‘: 94’675 Franz, Michael, “Emulating an Operating System on [22] Filed: Jul. 19, 1993 Top of Another”, 1993 by John Wiley & Sons, Ltd. [51] Int. Cl.6 .............................................. .. G06F 9/40 Primary Examiner-Kevin A. Kriess [52] US. Cl. .................................. .. 395/700; 364/280; Assistant Examiner—Matthew M. Payne 364/286; 364/ 976; 364/977.2; 395/500 Attorney, Agent, or Firm—Keith Stephens [58] Field of Search ....................................... .. 395/700 [57] ABSTRACT [56] References cued An apparatus for enabling an object-oriented applica U.S. PATENT DOCUMENTS tion to access in an object-oriented manner a procedural 4 456 954 M19“ Bunions) m et a1. " 364/200 operating system having a native procedural interface is 415301052 7/1985 King et a1. ............ .. 364/200 dlsclosed- The apparatus Includes a Computer and a 4,821,220 4/1989 Duisberg . .. 364/578 memory component In the computer A code library is 4,885,717 12/1989 Beck et a1. ........ .. 364/900 stored in the memory component. The code library 4,891,630 1/1990 Friedman et a1. .. 340/706 includes computer program logic implementing an ob 4,953,030 8/1990 Dysalft e! 81- --------- -- 364/200 ject-oriented class library. The object-oriented class 5041992 8/1991 cunmngham et a1‘ ' 364/518 library comprises related object-oriented classes for $1211: ‘1211' """"" " enabling the application to access in an object-oriented 5:075:848 12/1992 Lai et 211. 2.1.5.1‘. 595/425 manner sfirvices Provided by the °Perating System The 5,093,914 3/1992 Cop?en et a1_ __ 395/700 object-oriented classes include methods for accessing 5,119,475 6/ 1992 Smith et al. .. 395/ 156 the operating system services using procedural function 5,125,091 6/1992 Staas, Jr. et al. 395/650 calls compatible with the native procedural interface of 5,133,075 7/ 1992 RlSCh . .. 395/800 the operating system_ The computer processes object 5r136r705 8/1992 stubbs et a1‘ 395/575 oriented statements contained in the application and 5’151'987 9/1992 Abfaham et a1‘ 222/ de?ned by the class library by executing methods from 2:151:31 1211333 2233;681:1111: 3955700 rhs slsss lrbrsry corresponding rs rhs objssr-srrsrrsd 5,280,610 1/1994 Travis, Jr. et al. 395/600 Statements 5,287,507 2/1994 Hamilton et al. 395/650 5,293,385 3/ 1994 Hary .................................... .. 371/19 4 Claims, 17 Drawing Sheets START F 204 V LOCATE IN PROGRAM OBJECT-O 12 ENTED STATEMENT ACCESSING M 206 OPERATING SYSTEM ll THANSLATE OBJECT ORIENTED STATEMENT TO PROCEDURAL FUNCTION CALL COMPATIBLE WITH v208 PROCED URAL INTERFACE 0F OPERATING SYSTEM ll B<ECUTE PROC EDU RAL FUNCTION CALL ‘1 210 212 US. Patent Jan. 3, 1995 Sheet 2 of 17 5,379,432 202 204 LOCATE IN PROGRAM OBJECT-ORIENTED STATEMENT ACCESSING 206 OPERATING SYSTEM TRANSLATE OBJECT ORIENTED STATEMENT TO PROCEDURAL FUNCTION CALL COMPATIBLE WITH 208 PROCEDURAL INTERFACE OF OPERATING SYSTEM EXECUTE PROCEDURAL FUNCTION CALL 210 Figure 2 US. Patent Jan. s, 1995 Sheet 3 0f 17 5,379,432 3K @~ METHOD CODE IN TASK ADDRESS SPACE? LIBRARY SERVER FIND LIBRARY KNOWN? SERVER ACCESS LIBRARY SERVER AND COPY METHOD CODE FROM CODE LIBRARY TO TASK ADDRESS SPACE EXECUTE METHOD CODE Figure 3 US. Patent Jan. s, 1995 Sheet 4 0f 17 5,379,432 CODE THREAD CLASSES I 494 m LIBRARY 1 1O TASK CLASSES I 406 VIRTUAL MEMORY CLASSES I ,408 IPC CLASSES I‘ ,410 CLASS '\/ LIBRARY 402 SYNCHRONIZATION CLASSES|\,412 SCHEDULING CLASSES I 414 FAULT CLASSES I 416 MACHINE CLASSES I 418 SECURITY CLASSES I 420 Figure 4 US. Patent »‘ Jan. s, 1995 Sheet 7 of 17 5,379,432 2:9".h mmmmwm?omimob vi. Emgwiczcoh Non US. Patent Jan. s, 1995 Sheet 8 of 17 5,379,432 959".m 8226:Sw 59.2 mom vow?mmotawboémsc. boEmEmEdOSOF coEwoQwi EmmSSQcoEmE... mom US. Patent Jan. 3, 1995 Sheet 10 of 17 5,379,432 coEucoOhoscoik moo?coop :0’N2:0:: 22:2“ \.\ \\ 292E802 AEEwHSEoSC.xuodouucog.v woo?1/ mooF US. Patent Jan. 3, 1995 Sheet 11 of 17 5,379,432 3.: oicmInmmEt.E:_. ségowumezt. 2.6m2 0P: mo: mo: \\K8: US. Patent Jan. 3, 1995 Sheet 12 of 17 5,379,432 1 202 TFaultDesignation ( TI'askHandle ) 1 206 Tl'hreadHandle '1 1210 1 208 FaultAssociation ( TPortSendHightHandle ’ 1212 1212 TFaultTypeSet ( TFaultType ) EFaultMessageType 121 6 1218 1 220 \ 1222 TFaultType 1230 1 224 TMCsaoxoFault-rype - etc. for all possible 68K faults ( TMC68OXOAddressFault ) ( mcsaoxoBadAcoessFault ’ 1226 1228 Figure 12 US. Patent Jan. 3, 1995 Sheet 14 of 17 5,379,432 k2=28comm85:26?c.Sun9:22m9: m5 325223m 23E3 v83/‘@8956”; / ?mommmognmmh mow? US. Patent Jan. s, 1995 Sheet 15 of 17 5,379,432 82952m2. shows.29939 222350.“. VEEPA$58885 V82).‘#58885 BSwDnEOXQQQOE 3EVA2230805;mosmm?smoxowwog mmEmExoEwoXommOSC.:3w gmuwummhct. momP comp amesmvagmoxommozh momF US. Patent Jan. a, 1995 Sheet 16 of 17 5,379,432 25E2 065163829?$9wizmIummEC. 5?osucwzxwmt.sucm?uwozuomgzih c .Pc 0 \c0651.85. Na: cmow? F c momF mooF US. Patent Jan. 3, 1995 Sheet 17 of 17 5,379,432 EaEaomam:2;m‘III HHOAAJ$08.258:m8: ‘J3:AcgaememaéHU$9 ‘wt63u.vf3.“A“ 2.5m2 3263x 3?_onm_x 5,379,432 1 2 A second “fringe bene?t” of good encapsulation in OBJECT-ORIENTED INTERFACE FOR A object-oriented design and programming is that the PROCEDURAL OPERATING SYSTEM resulting code is more modular and maintainable than code written using more traditional techniques. A portion of the disclosure of this patent application 5 The fact that objects are encapsulated produces an contains material which is subject to copyright protec other important fringe bene?t that is sometimes referred tion. The copyright owner has no objection to the fac to as data abstraction. Abstraction is the process by simile reproduction by anyone of the patent disclosure, which complex ideas and structures are made more as it appears in the Patent and Trademark Of?ce patent understandable by the removal of detail and the gener ?les or records, but otherwise reserves all copyright alization of their behavior. From a software perspec rights whatsoever. tive, abstraction is in many ways the antithesis of hard coding. Consider a software windowing example: if FIELD OF THE INVENTION every detail of every window that appears on a user’s The present invention relates generally to object-ori screen in a graphical user interface (GUI)-based pro ented computing environments, and more particularly 5 gram had to have all of its state and behavior hard to a system and method for providing an object-ori coded into a program, then both the program and the ented interface for a procedural operating system. windows it contains would lose almost all of their ?exi bility. By abstracting the concept of a window into a BACKGROUND OF THE INVENTION window object, object-oriented systems permit the pro Object-oriented technology (OOT), which generally 20 grammer to think only about the speci?c aspects that includes object-oriented analysis (OOA), object-ori make a particular window unique. Behavior shared by ented design (00D), and object-oriented programming all windows, such as the ability to be dragged and (GOP), is earning its place as one of the most important moved, can be shared by all window objects. new technologies in software development. OOT has This leads to another basic component of OOT, already begun to prove its ability to create signi?cant which is the class. A class includes a set of data attri increases in programmer productivity and in program butes plus a set of allowable operations (that is, meth maintainability. By engendering an environment in ods) on the data attributes. Each object is an instance of which data and the procedures that operate on the data some class. As a natural outgrowth of encapsulation and are combined into packages called objects, and by abstraction, OOT supports inheritance. A class (called a adopting a rule that demands that objects communicate subclass) may be derived from another class (called a with one another only through well-de?ned messaging base class, a'parent class, etc.) wherein the subclass paths, OOT removes much of the complexity of tradi inherits the data attributes and methods of the base tional, procedure-oriented programming. class. The subclass may specialize the base class by The following paragraphs present a brief overview of adding code which overrides the data and/or methods some of the more important aspects of OOT. More of the base class, or which adds new data attributes and detailed discussions of OOT are available in many pub methods. Thus, inheritance represents a mechanism by licly available documents, including Object Oriented which abstractions are made increasingly concrete as Design With Applications by Grady Booch (Benjamin/ subclasses are created for greater levels of specializa Cummings Publishing Company, 1991) and Object-Ori tion.
Recommended publications
  • Moving FLASK to BSD Systems
    MovingMoving FLASKFLASK toto BSDBSD SSystemsystems SELinux Symposium 2006 Chris Vance Information Systems Security Operation, SPARTA, Inc. Vance_20060301_01 Overview • Security Frameworks • A Brief History • SELinux Inspired… – Security Enhanced BSD – Security Enhanced Darwin Vance_20060301_02 Security Frameworks • Traditional UNIX security isn’t enough – OS hardening – Mandatory protection – Flexible, manageable, scalable protection • Support required in the operating system for new security services – Costs of locally maintaining security extensions are high – Framework offers extensibility so that policies may be enhanced without changing the base operating system • There does not appear to be one perfect security model or policy – Sites may have different security/performance trade-offs – Sites may have special local requirements – Vendors unlikely to adopt a single policy • Bottom Line: Frameworks for Linux, FreeBSD, Darwin Vance_20060301_03 How We Got Here… Vance_20060301_04 Focus and Reuse • Don’t “reinvent” security – Learn from the past – The research is often decades old – A good design is durable, doesn’t require constant change – FLASK hasn’t changed much recently, what’s that mean? • Leverage existing technology, focus on “new” issues – Focus on improving operating system security – Spend the time to get Frameworks correct – Work with vendor for acceptance – Develop rule sets that work – Develop effective tools to manage policy • Do innovate – Don’t stop thinking! – Don’t squash new ideas – Re-factor old ideas Vance_20060301_05
    [Show full text]
  • Operating System Structure
    Operating System Structure Joey Echeverria [email protected] modified by: Matthew Brewer [email protected] Nov 15, 2006 Carnegie Mellon University: 15-410 Fall 2006 Overview • Motivations • Kernel Structures – Monolithic Kernels ∗ Kernel Extensions – Open Systems – Microkernels – Exokernels – More Microkernels • Final Thoughts Carnegie Mellon University: 15-410 Fall 2006 1 Motivations • Operating systems have a hard job. • Operating systems are: – Hardware Multiplexers – Abstraction layers – Protection boundaries – Complicated Carnegie Mellon University: 15-410 Fall 2006 2 Motivations • Hardware Multiplexer – Each process sees a “computer” as if it were alone – Requires allocation and multiplexing of: ∗ Memory ∗ Disk ∗ CPU ∗ IO in general (network, graphics, keyboard etc.) • If OS is multiplexing it must also allocate – Priorities, Classes? - HARD problems!!! Carnegie Mellon University: 15-410 Fall 2006 3 Motivations • Abstraction Layer – Presents “simple”, “uniform” interface to hardware – Applications see a well defined interface (system calls) ∗ Block Device (hard drive, flash card, network mount, USB drive) ∗ CD drive (SCSI, IDE) ∗ tty (teletype, serial terminal, virtual terminal) ∗ filesystem (ext2-4, reiserfs, UFS, FFS, NFS, AFS, JFFS2, CRAMFS) ∗ network stack (TCP/IP abstraction) Carnegie Mellon University: 15-410 Fall 2006 4 Motivations • Protection Boundaries – Protect processes from each other – Protect crucial services (like the kernel) from process – Note: Everyone trusts the kernel • Complicated – See Project 3 :) – Full
    [Show full text]
  • Chapter 2 Operating System Structures
    Operating Systems Associate Prof. Yongkun Li 中科大-计算机学院 副教授 http://staff.ustc.edu.cn/~ykli Chapter 2 Operating System Structures 1 Objectives • Operating System Services – User Operating System Interface – System Calls • Operating System Structure • Operating System Design and Implementation • MISC: Debugging, Generation & System Boot 2 Operating System Services Services Overview, User Interface 3 Operating System Services • Operating systems provide – an environment for execution of programs and – services to programs and users • Services may differ from one OS to another • What are the common classes? – Convenience of the user – Efficiency of the system 4 Overview of Operating System Services 5 OS Services for Helping Users • User interface - Almost all operating systems have a user interface (UI). – Three forms • Command-Line (CLI) – Shell command • Batch – Shell script • Graphics User Interface (GUI) – Windows system 6 OS Services for Helping Users • Program execution – Load a program into memory – Run the program – End execution • either normally or • abnormally (indicating error) 7 OS Services for Helping Users • I/O operations - A running program may require I/O, which may involve a file or an I/O device – Common I/Os: read, write, etc. – Special functions: recording CD/DVD • Notes: Users usually cannot control I/O devices directly, so OS provides a mean to do I/O – Mainly for efficiency and protection 8 OS Services for Helping Users • File-system manipulation - The file system is of particular interest – OS provides a variety of file systems • Major services – read and write files and directories – create and delete files and directories – search for a given file – list file Information – permission management: allow/deny access 9 OS Services for Helping Users • Communications: information exchange between processes – Processes on the same computer – Processes between computers over a network • Implementations – Shared memory • Two or more processes read/write to a shared section of mem.
    [Show full text]
  • Darwin: Mac OS X's Core OS
    ADC April 2001 3/8/01 1:57 PM Page 1 Apple Developer Connection Direct Darwin: Mac OS X’s Core OS eneath Mac OS X’s user-friendly and attractive user interface, Most of the reference documents can be Aqua, and the application frameworks (Classic, Carbon and found in the /Developer/Documentation/ BCocoa) is Darwin: Mac OS X’s core OS. Unseen by users, Kernel directory on any Mac OS X system Darwin provides a strong yet flexible foundation with features like with the Mac OS X Developer Tools package preemptive multitasking, protected memory and real-time support installed. that make Mac OS X a truly modern operating system. The focus of this article is to provide a brief overview of Components of Darwin Darwin and its components as well as give an introduction to Just like in the old Reese’s Peanut Butter developing kernel extensions—modules that extend Darwin’s Cups commercials (“You’ve got chocolate in functionality. For more in-depth information, you should read my peanut butter… No, you’ve got peanut butter on my choco- Inside Mac OS X: Kernel Environment which is available, along late!”), Darwin blends a mixture of mature industry standard com- with other documents referred to in this article, on the Apple ponents such as Mach and BSD with Apple-engineered components Developer Connection (ADC) web site in the Mac OS X to provide Mac OS X with a stable, reliable and extensible founda- Documentation section: tion. Darwin consists of five main components: Mach, I/O Kit, File http://developer.apple.com/techpubs/macosx/macosx.html System, Networking and BSD.
    [Show full text]
  • Mach-O Internals
    Mach-O Internals William Woodru February 10, 2016 1 / 31 General Agenda 1. Who are you? 2. What is Mach-O? 3. An Extremely Brief History of Mach and Mach-O 4. Structure of a Mach-O File 5. Quirks Encountered 6. Concluding Notes 2 / 31 Who are you? My name is William Woodru. I'm a Computer Science major and Philosophy minor at the University of Maryland, College Park. Outside of school, I'm a member of the Homebrew project and a regular contributor to several open source groups. My work for Homebrew is largely concerned with the underlying system interface and reconciling OS X's intricacies/irregularities with the package manager. 3 / 31 What is Mach-O? Mach-O is the Mach Object binary format. Mach-O is used primarily by Apple in OS X and iOS. Apps on both platforms are really just directory trees containing Mach-O binaries and resources (fonts, icons, congurations). Metadata is stored in a number of places, but mainly within bundled plists (XML) and the binaries themselves. Like its cousins on Linux (ELF) and Windows (PE), Mach-O supports multiple object types: I Executable I Core dump I Shared library/object I Prelinked object le I etc. 4 / 31 . and multiple architectures: I m68k/m88k (yes, it's still supported!*) I x86 I AMD64 I POWER I ARMv6/7/8 Unlike ELF or PE, Mach-O has been extended to allow multi-architecture fat binaries. This has resulted in some interesting properties not shared by the other two. More on that later.
    [Show full text]
  • Evolving Mach 3.0 to a Migrating Thread Model
    Evolving Mach to a Migrating Thread Mo del Bryan Ford Jay Lepreau University of Utah Abstract Wehave mo died Mach to treat crossdomain remote pro cedure call RPC as a single entity instead of a sequence of message passing op erations With RPC thus elevated we improved the transfer of control during RPC bychanging the thread mo del Like most op erating systems Mach views threads as statically asso ciated with a single task with two threads involved in an RPC An alternate mo del is that of migrating threads in which during RPC a single thread abstraction moves b etween tasks with the logical owofcontrol and server co de is passively executed Wehave compatibly replaced Machs static threads with migrating threads in an attempt to isolate this asp ect of op erating system design and implementation The key elementof our design is a decoupling of the thread abstraction into the execution context and the schedulable thread of control consisting of a chain of contexts A key element of our implementation is that threads are now based in the kernel and temp orarily make excursions into tasks via up calls The new system provides more precisely dened semantics for thread manipulation and additional control op erations allows scheduling and accounting attributes to follow threads simplies kernel co de and improves RPC p erformance Wehave retained the old thread and IPC interfaces for backwards compatibility with no changes required to existing client programs and only a minimal change to servers as demonstrated by a functional Unix single server
    [Show full text]
  • Mach: a System Software Kernel Abstract
    Mach: A System Software Kernel Richard Rashid, Daniel Julin, Douglas Orr, Richard Sanzi, Robert Baron, Alessandro Forin, David Golub, Michael Jones Department of Computer Science Carnegie Mellon University Pittsburgh, Pennsylvania 15213 Abstract for a 16-bit uniprocessor. Under the weight of changing needs and technology, Unix has been modified to provide a The Mach operating system can be used as a system staggering number of different mechanisms for managing ob- software kernel which can support a variety of operating jects and resources. In addition to pipes, Unix versions now system environments. Key elements of the Mach design support facilities such as System V streams, 4.2BSD sockets, which allow it to efficiently support system software include pty's, various forms of semaphores, shared memory and a integrated virtual memory management and interprocess com- munication, multiple threads of control within one address mind-boggling array of ioctl operations on special files and space, support for transparent system trap callout and an ob- devices. The result has been scores of additional system calls ject programming facility integrated with the Mach IPC and options with less than uniform access to different mechanisms. Mach is currently available both from CMU resources within a single Unix system and within a network of and commercially on a wide range of uniprocessor and mul- tiprocessor hardware. Unix machines. The Mach operating system kernel developed at Carnegie 1. Introduction Mellon University [1] was designed to operate on both uniprocessors and multiprocessors and to provide a small set The operating system software problems faced by manufac- of basic facilities which would permit a wide variety of turers are often magnified by a need for compatibility be- operating system environments to be efficiently implemented.
    [Show full text]
  • 01.Answers Even.Osx
    1 Answers to Even-numbered Exercises 1. 2. What is the Free Software Foundation/GNU? BSD? Mach? Which parts of the Mac OS X operating system did each provide? The Free Software Foundation (www.fsf.org) is the principal organizational sponsor of the GNU Project. GNU developed many of the tools, including the C compiler, that are part of Mac OS X. BSD stands for Berkeley Software Distribution; it describes the code released by the University of California at Berkeley. Mach is an operating system kernel developed at CMU. Mac OS X uses some GNU tools, such as the GNU C compiler, and the bash shell, a lot of BSD tools and utilities, and the Mach kernel. 3. 4. How can you use utility programs and a shell to create your own applications? You can write a shell script, also called a shell program, or a batch file under DOS. A shell script is one or more command lines contained in a file. Make the file executable and give the name of the file as a command: The shell then executes the commands in the file as though you had typed each command individually. (You may need to give the command as ./command.) 5. 6. What is the difference between a multiprocessor and a multiprocessing system? Multiprocessor (having more than one processor) refers to a system with two or more processors or CPUs. Multiprocessing (supporting multiple processes) refers to a system that can process one or more tasks at a time. 1 2 Answers to Even-numbered Exercises 7. 8.
    [Show full text]
  • An Operating System
    Page 1 of 7 What is an Operating System 2.1 Examples: An operating system (OS) is software that manages computer hardware and software resources and provides common services for computer programs. The operating system is an essential component of the system software in a computer system. Application programs usually require an operating system to function. Unix and Unix-like operating systems Unix was originally written in assembly language.[6] Ken Thompson wrote B, mainly based on BCPL, based on his experience in the MULTICS project. B was replaced by C, and Unix, rewritten in C, developed into a large, complex family of inter-related operating systems which have been influential in every modern operating system (see History). The Unix-like family is a diverse group of operating systems, with several major sub-categories including System V, BSD, and Linux. The name "UNIX" is a trademark of The Open Group which licenses it for use with any operating system that has been shown to conform to their definitions. "UNIX-like" is commonly used to refer to the large set of operating systems which resemble the original UNIX. Unix-like systems run on a wide variety of computer architectures. They are used heavily for servers in business, as well as workstations in academic and engineering environments. Free UNIX variants, such as Linux and BSD, are popular in these areas. Four operating systems are certified by The Open Group (holder of the Unix trademark) as Unix. HP's HP-UX and IBM's AIX are both descendants of the original System V Unix and are designed to run only on their respective vendor's hardware.
    [Show full text]
  • Operating Systems, 1997., the Sixth Work
    Experience with the Development of a Microkernel-Based, Multiserver Operating System Freeman L. Rawson I11 IBM Austin Abstract and feel” of any operating system in the set while maintaining a single system image that shared as much code as possible among the During the first half the 1990s IBM developed a set . of of personalities operating system products called Worhplace OS that was bused . that offered full compatibility with all of the operating on the Mach 3.0 microkernel and Taligent’s object-oriented systems in the set and with DOSlWindows 3.1 TalOS. These products were intended to be scalable, portable + which offered the choice of a fully object-oriented and capable of concurrently running multiple operating system operating system including both object-oriented interfaces personalities while sharing as much code as possible. The and an object-oriented implementation operating system personalities were constructed out of a set of - which provided real time operation. user-level personality and personality-neutral servers and Since the technologies were modular, the project was libraries. While we made a number of important changes to structured as a set of related products so that customers could Mach 3.0, we maintained its fundamentals and the multi-server buy precisely the parts that they needed. The project as a design throughout our project. In evaluating the resulting system, whole was known as Workplace OS (WPOS) but was often a number ofproblems are apparent. There is no good way to referred to as the “microkemel-based” system because of the factor multiple existing systems into a set of functional servers central role played by the microkernel and because the without making them excessively large and complex.
    [Show full text]
  • Microkernels: Mach and L4
    Microkernels: Mach and L4 Presented by Jason Wu With content borrowed from Dan Williams (2009) and Hakim Weatherspoon (2008) Outline • Introduction to Kernels • 1st Generation Microkernels – Mach • 2nd Generation Microkernels – L4 • Conclusions Introduction to Kernels • Different Types of Kernel Designs – Monolithic kernel – Microkernel – Hybrid Kernel – Exokernel – Virtual Machines? Monolithic Kernels • All OS services operate in kernel space • Good performance • Disadvantages – Dependencies between system component – Complex & huge (millions(!) of lines of code) – Larger size makes it hard to maintain • E.g. Multics, Unix, BSD, Linux Microkernels • Minimalist approach – IPC, virtual memory, thread scheduling • Put the rest into user space – Device drivers, networking, file system, user interface • More stable with less services in kernel space • Disadvantages – Lots of system calls and context switches • E.g. Mach, L4, AmigaOS, Minix, K42 Monolithic Kernels VS Microkernels Hybrid Kernels • Combine the best of both worlds – Speed and simple design of a monolithic kernel – Modularity and stability of a microkernel • Still similar to a monolithic kernel – Disadvantages still apply here • E.g. Windows NT, NetWare, BeOS Exokernels • Follows end-to-end principle – Extremely minimal – Fewest hardware abstractions as possible – Just allocates physical resources to apps • Disadvantages – More work for application developers • E.g. Nemesis, ExOS • Next Thursday! The Microkernel Debate • How big should it be? • Big debate during the 1980’s Summary:
    [Show full text]
  • A Secure Computing Platform for Building Automation Using Microkernel-Based Operating Systems Xiaolong Wang University of South Florida, [email protected]
    University of South Florida Scholar Commons Graduate Theses and Dissertations Graduate School November 2018 A Secure Computing Platform for Building Automation Using Microkernel-based Operating Systems Xiaolong Wang University of South Florida, [email protected] Follow this and additional works at: https://scholarcommons.usf.edu/etd Part of the Computer Sciences Commons Scholar Commons Citation Wang, Xiaolong, "A Secure Computing Platform for Building Automation Using Microkernel-based Operating Systems" (2018). Graduate Theses and Dissertations. https://scholarcommons.usf.edu/etd/7589 This Dissertation is brought to you for free and open access by the Graduate School at Scholar Commons. It has been accepted for inclusion in Graduate Theses and Dissertations by an authorized administrator of Scholar Commons. For more information, please contact [email protected]. A Secure Computing Platform for Building Automation Using Microkernel-based Operating Systems by Xiaolong Wang A dissertation submitted in partial fulfillment of the requirements for the degree of Doctor of Philosophy in Computer Science and Engineering Department of Computer Science and Engineering College of Engineering University of South Florida Major Professor: Xinming Ou, Ph.D. Jarred Ligatti, Ph.D. Srinivas Katkoori, Ph.D. Nasir Ghani, Ph.D. Siva Raj Rajagopalan, Ph.D. Date of Approval: October 26, 2018 Keywords: System Security, Embedded System, Internet of Things, Cyber-Physical Systems Copyright © 2018, Xiaolong Wang DEDICATION In loving memory of my father, to my beloved, Blanka, and my family. Thank you for your love and support. ACKNOWLEDGMENTS First and foremost, I would like to thank my advisor, Dr. Xinming Ou for his guidance, encouragement, and unreserved support throughout my PhD journey.
    [Show full text]