OS Concepts Chapter 2 Solution To Practice Exercises Part 2
System programs provide basic functionality to users so they do not need to write their own programs to solve common problems. The layered approach to system design makes the operating system easier to debug and modify by limiting the impact of changes. Some key services provided by an operating system include program execution, I/O operations, file system manipulation, communications, and error detection. User programs cannot reliably provide these services due to issues around resource allocation, device access control, and handling process-independent errors.
Download as DOCX, PDF, TXT or read online on Scribd
100%(2)100% found this document useful (2 votes)
655 views
OS Concepts Chapter 2 Solution To Practice Exercises Part 2
System programs provide basic functionality to users so they do not need to write their own programs to solve common problems. The layered approach to system design makes the operating system easier to debug and modify by limiting the impact of changes. Some key services provided by an operating system include program execution, I/O operations, file system manipulation, communications, and error detection. User programs cannot reliably provide these services due to issues around resource allocation, device access control, and handling process-independent errors.
Download as DOCX, PDF, TXT or read online on Scribd
You are on page 1/ 2
Practice Exercises
2.7 What is the purpose of system programs?
Answer: System programs can be thought of as bundles of useful system calls. They provide basic functionality to users so that users do not need to write their own programs to solve common problems. 2.8 What is the main advantage of the layered approach to system design? What are the disadvantages of using the layered approach? Answer: As in all cases of modular design, designing an operating system in a modular way has several advantages. The system is easier to debug and modify because changes affect only limited sections of the system rather than touching all sections of the operating system.Information is kept only where it is needed and is accessible only within a defined and restricted area, so any bugs affecting that data must be limited to a specific module or layer. 2.9 List five services provided by an operating system. Explain how each provides convenience to the users. Explain also in which cases it would be impossible for userlevel programs to provide these services. Answer: a.Program execution. The operating system loads the contents (or sections) of a file into memory and begins its execution. A user-level program could not be trusted to properly allocate CPU time. b.I/O operations. Disks, tapes, serial lines, and other devices must be communicated with at a very low level. The user need only specify the device and the operation to perform on it, while the system converts that request into device- or controller-specific commands. User-level programs cannot be trusted to access only devices they should have access to and to access them only when they are otherwise unused. c.File-system manipulation. There are many details in file creation,deletion, allocation, and naming that users should not have to perform. Blocks of disk space are used by files and must be tracked. Deleting a file requires removing the name file information and freeing the allocated blocks. Protections must also be checked to assure proper file access. User programs could neither ensure adherence to protection methods nor be trusted to allocate only free blocks and deallocate blocks on file deletion. d.Communications.
Message passing between systems requires messages to be turned into packets of
information, sent to the network controller, transmitted across a communications medium,and reassembled by the destination system. Packet ordering and data correction must take place. Again, user programs might not coordinate access to the network device, or they might receive packets destined for other processes. e.Error detection. Error detection occurs at both the hardware and software levels. At the hardware level, all data transfers must be inspected to ensure that data have not been corrupted in transit. All data on media must be checked to be sure they have not changed since they were written to the media. At the software level, media must be checked for data consistency; for instance, whether the number of allocated and unallocated blocks of storage match the total number on the device. There, errors are frequently process-independent (for instance, the corruption of data on a disk), so there must be a global program (the operating system) that handles all types of errors. Also, by having errors processed by the operating system, processes need not contain code to catch and correct all the errors possible on a system. 2.10 Why do some systems store the operating system in firmware, and others on disk? Answer: For certain devices, such as handheld PDAs and cellular telephones, a disk with a file system may be not be available for the device. In this situation, the operating system must be stored in firmware. 2.11 How could a system be designed to allow a choice of operating systems to boot from? What would the bootstrap program need to do? Answer: Consider a system that would like to run both Windows XP and three different distributions of Linux (e.g., RedHat, Debian, and Mandrake). Each operating system will be stored on disk. During system boot-up, a special program (which we will call the boot manager) will determine which operating system to boot into. This means that rather initially booting to an operating system, the boot manager will first run during system startup. It is this boot manager that is responsible for determining which system to boot in to. Typically boot managers must be stored at certain locations of the hard disk to be recognized during system startup. Boot managers often provide the user with a selection of systems to boot into; boot managers are also typically designed to boot into a default operating system if no choice is selected by the user.