

#### Capítulo 2: Estruturas dum Computador

#### SUMÁRIO:

- 2.1 Bios e BootStrap
- 2.2 Funcionamento dum Computador
  - Interrupções
- 2.2 Arquitectura de I/O
  - Hardware I/O
  - Alternativa a Interupções Polling
  - Método Síncrono, Assíncrono,
  - Interface I/O
  - DMA
- 2.3 Estrutura de Armazenamento
  - Hierarquia de Armazenamento
- 2.4 Protecção do Hardware
  - Dual Mode

Operating System Concepts

2.1

Silberschatz, Galvin and Gagne ©2002





# Computer Startup BIOS e BOOSTRAP

#### BIOS

- sigla para Basic Input/Output System (Sistema Básico de Entrada/Saída)
- O BIOS é o primeiro programa executado pelo computador ao ser ligado.
- Sua função é preparar a máquina para que o SO, que pode estar armazenado em diversos tipos de dispositivos (discos rígidos, disquetes, CDs, etc) possa ser carregado para memoria e iniciado a sua execução.
- O BIOS é Firmware.
  - Firmware: Qualquer Software armazenado sob a forma de memória de leitura não-volatil, ROM, EPROM, EEPROM etc.





Operating System Concepts

2.2



## **BootStrap**

#### ■O Programa "bootstrap"

- Um programa carregado durante "power-up" ou "reboot" pelo BIOS. O BIOS não sabe nada sobre a ambiente necessário para um SO
- O BIOS apena inicialize o hardware para um estado "conhecido".
- O BIOS transfere controlo para o programa bootsrap que Initialize todas as partes do sistema necessário para carregar o kernel do SO.
- O Bootstrap, deverá localizar e carregar o kernel do sistema operativo para memória e initialize a sua execução ou fazer um processo mais complexo (multiboot etc.)
- Fixemplos GRUB, LILO, WINLOAD etc.



Operating System Concepts



## Funcionamento dum computador

- Controladores I/O e a CPU podem executar duma forma concorrente.
- Cada controlador está encarregue dum tipo de dispositivo particular.
- Cada controlador tem um buffer local.
- A CPU movimenta dados de (para) memória principal para (a partir de) os buffers locais.
- I/O é a partir do dispositivo para o buffer local do controlador.
- O controlador informa a CPU que terminou a sua operação através duma interrupção.



Arquitectura .. dum computador



Operating System Concepts

2.4



# Funções desempenhadas por interrupções

- Uma interrupção transfere o controlo para uma <u>rotina de serviço</u> através do *interrupt vector*, o qual contém os endereços de todas as rotinas de serviço à interrupção.
- A arquitectura de interrupções tem de guardar o endereço da instrução interrompida.
- As interrupções entretanto chegadas são disabled enquanto outra interrupção está sendo processada por forma a impedir a sua perda.
- Uma interrupção gerada por software, devido a um erro p.ex., divisão por zero, acesso inválido à memória ou a um pedido do utilizador (ctrl-c) é chamado uma "trap".
- A rotina de Serviço (Interrupt Service Routine -ISR)implemente a fuhncionalidade da interrupção
- Um sistema operativo é *interrupt* driven.

Explicar !!

Windows device manager

Silberschatz, Galvin and Gagne ©2002

Operating System Concepts

2.5

XEMPLO: Comunicação CPU-Dispositivo I/O via Interrupções

 Durante I/O, interrupções são feitas por vários dispositivos quando eles ficam prontos para serviço.

- Estas interrupções significam que a saída de dados terminou, ou que a entrada de dados está disponível, ou que uma falha foi detectada.
- O controlador interrompe a CPU através da emissão dum sinal na linha de pedido de interrupção;
- A CPU detecta a interrupção e despacha-a para o interrupt handler, que é uma rotina
- A interrupt handler determina a causa da interrupção, faz o processamento necessário (rotina de serviço à interrupção) e termina; ao terminar, a CPU voltaao estado anterior à interrupção

I/O controller device driver initiates I/O initiates I/O CPU executing checks for nterrupts between instruction input ready, output CPU receiving interrupt, transfers control to complete, or error interrupt handler nerates interrupt signal processes data returns from interrupt 6 CPU resumes processing of Ciclo I/O alimentado por interrupções

Operating System Concepts

Silberschatz, Galvin and Gagne ©2002



# Tabela de eventos do processador Intel Pentium

A maior parte das CPUs tem agora duas linhas de interrupção:

 Linha de interrupção nãomascarável, que é reservada para eventos tais como erros de memória irrecuperáveis

Linha de interrupção mascarável, que pode ser desligada pela CPU antes da execução duma sequência de instruções críticas que não podem serem interrompidas.

 Vector de interrupções para despachar cada interrupção para o handler correcto

Baseado em prioridades

Algumas não são mascaráveis (os primeiros 32 eventos do Intel Pentium não são mascaráveis e são usadas para sinalização de erros) debug exception
null interrupt
standard and several an

description

■Mecanismo de interrupções também usado para excepções

(p.ex. divisão por 0, acesso a endereço de memória protegida ou inexistente)

Operating System Concepts

2.7

Silberschatz, Galvin and Gagne ©2002



## Manipulação de interrupções

- Repare que para tratar duma interupção
  - O sistema operativo preserva o estado da CPU
  - registadores contador de programa etc.
  - Estado do cpu é chamado o "contexto"
- O Interrupt Handler do sistema operativo determinam que acção deve ser tomada para cada tipo de interrupção.

2.8

- Comunicação CPU-Dispositivo I/O
  - vectored interrupt system
    - fazer lookup numa tabela
  - Alternativa : Polling
    - pedir ao hardware



Operating System Concepts

#### Hardware I/O

Every transfer is an output from one device and an input into another."

- Como é que a CPU pode fornecer comandos e dados a um controlador para efectuar uma transferência I/O?
  - O controlador tem um ou mais registos para dados (registo data-in, registo data-out) e sinais de controlo (registo status e registo control)
  - A CPU comunica com o controlador através da leitura e escrita de "padrões de bits" nestes registos
- Duas formas de comunicação **CPU-controlador:** 
  - Instruções I/O directas (1 byte + endereço de porto
  - Instruções I/O mapeadas em memória

| I/O address range (hexadecimal) | device                    |  |
|---------------------------------|---------------------------|--|
| 000-00F                         | DMA controller            |  |
| 020-021                         | interrupt controller      |  |
| 040-043                         | timer                     |  |
| 200-20F                         | game controller           |  |
| 2F8-2FF                         | serial port (secondary)   |  |
| 320-32F                         | hard-disk controller      |  |
| 378-37F                         | parallel port             |  |
| 3D0-3DF                         | graphics controller       |  |
| 3F0-3F7                         | diskette-drive controller |  |
| 3F8-3FF                         | serial port (primary)     |  |

Localizações de alguns portos I/O de dispositivos de PCs

Operating System Concepts

2.9

Silberschatz, Galvin and Gagne ©2002

## Hardware I/O:

## Comunicação CPU-Dispositivo I/O via Polling Espera Ocupada da CPU

A interacção entre a CPU e um controlador faz-se por aperto de mão (handshaking). Assuma que são usados 2 bits (busy bit do registo status e ready bit do registo command do controlador) para coordenar a relação produtor-consumidor entre o controlador e a CPU:

- Determines state of device
  - command-ready

  - Error
- Busy-wait cycle to wait for I/O from device



Operating System Concepts

2.10



## **Busy Wait**

- A CPU lê repetidamente o bit busy até que seja 0 (busy-wait cycle).
- A CPU activa o bit write a 1 no registo command e escreve um byte no registo data-out.
- A CPU activa o bit **ready** a 1 no registo command.
- Quando o controlador nota que o bit ready está a 1, it escreve o bit busy a 1.
- O controlador lê o registo command e vê o comando write. Lê o registo data-out para obter o byte, fazendo de seguida a I/O para o dispositivo.
- O controlador desactiva o bit **ready** a 0, assim como o bit **error** no registo status, para indicar que a transferência foi bem sucedida, colocando depois o bit busy a 0 para indicar que a transferência terminou.

Operating System Concepts

Silberschatz, Galvin and Gagne @2002



## Método Síncrono de I/O

- MÉTODO SÍNCRONO. Após o início duma operação I/O, o controlo só retorna ao programa do utilizador depois da terminação desta operação I/O.
- Implementação: A instrução wait (se existir) coloca a CPU num estado de espera até à próxima interrupção. Alternativamente utilize-se um ciclo tipo Wait
- Desvantagens -
  - No máximo um pedido I/O é atendido de cada vez.
  - Não existe nenhum processamento I/O simultâneo.
  - Contenção para acesso à memória (caso do ciclo Wait).



Operating System Concepts Método I/O síncrono

requesting process device driver interrupt handler kerne hardware data transfer

Método:1/0 assincreno:2002 5





#### Interface de I/O:

## Características dos dispositivos de I/O

- Dispositivos diferenciam-se de várias maneiras:
  - Character-stream ou block. Um dispositivo de caracteres transfere bytes um-a-um, ao passo que um dispositivo de blocos transfere um bloco de bytes como se fosse uma unidade.
  - Sequenciais ou de acesso aleatório
  - Síncronos ou assíncronos. Transferência de dados é feita com tempos de resposta previsíveis ou não.
  - Partilháveis ou dedicados. Há partilha concorrente por vários processos ou não.
  - Velocidade de operação
  - read-write, read only, ou write only

Operating System Concepts

| aspect             | variation                                                         | example                               |
|--------------------|-------------------------------------------------------------------|---------------------------------------|
| data-transfer mode | character<br>block                                                | terminal<br>disk                      |
| access method      | sequential<br>random                                              | modem<br>CD-ROM                       |
| transfer schedule  | synchronous<br>asynchronous                                       | tape<br>keyboard                      |
| sharing            | dedicated<br>sharable                                             | tape<br>keyboard                      |
| device speed       | latency<br>seek time<br>transfer rate<br>delay between operations |                                       |
| I/O direction      | read only<br>write only<br>readĐwrite                             | CD-ROM<br>graphics controller<br>disk |



2.15

## Interface de I/O: dispositivos de blocos e de caracteres

- Os dispositivos de blocos incluem os discos rígidos
  - Interface básica: read, write, seek
  - Modos de acesso:
    - Acesso de alto-nível através de interface de sistema de ficheiros
    - Acesso de baixo-nível através array linear de blocos (raw I/O)
    - Acesso a memory-mapped files colocadas no topo de block-device drivers é possível. Uma memorymapped interface fornece acesso ao disco através dum array de bytes em memória principal.
- Os dispositivos de caracteres (stream character) incluem teclados, ratos e portos série
  - Interface básica: get, put
  - No topo da interface, é possível construir bibliotecas para edição de linhas (p.ex. Eliminar um carácter do input stream através de backspace).

Operating System Concepts











2.16



#### Interface de I/O:

Dispositivos de rede

Têm uma interface bastante diferente da interface readwrite-seek usada pelos discos rígidos.





- Unix e Windows NT/9i/2000 usam uma interface de sockets
  - Há a separação entre o protocolo de rede e o funcionamento da rede
  - Inclui a funcionalidade select para manipular conjuntos de sockets
- Abordagens muito variadas (pipes, FIFOs, streams, queues, mailboxes)

**Ethernet Adapter Cards** 





PCMCIA compatible Fax/Modem cards







Silberschatz, Galvin and Gagne ©2002



Operating System Concepts

2.17

## Interface de I/O:

## Relógios (clocks) e temporizadores (timers)

- Fornecem três funções básicas para:
  - Determinar tempo corrente
  - Determinar tempo decorrido
  - Activar um temporizador para despoletar uma operação numa dada altura
- Um programmable interval timer é usado para suportar a segunda e terceira funções anteriores. (Este mecanismo é usado pelo escalonador para gerar uma interrupção que preempciona um processo no fim de esgotar o seu time-slice (algoritmo Round-Robin - Capitulo 5)
- A função ioctl (UNIX) aborda aspectos de I/O tais como relógios e temporizadores.





## **Estrutura DMA (Direct Memory Access)**

- .O DMA permite que certos dispositivos de hardware num computador acedam a memória do sistema para efectuar operações de I/O (leitura e escrita) independentemente da CPU.
- É usada em dispositivos I/O de alta-velocidade capazes de transmitir informação a velocidades próximas das memórias.
- O controlador de dispositivo transfere blocos de dados do buffer directamente para a memória principal sem intervenção da CPU.
- Só uma interrupção é gerada por bloco, em vez de uma interrupção por byte.
- Permite execução simultaneo do CPU e operações do I/O



Operating System Concepts

2.19

Silberschatz, Galvin and Gagne @2002



### **DMA** Funcionamento

- Data transfer can be triggered in two ways:
  - either the software asks for data (via a function such as read) or
  - the hardware asynchronously pushes data to the system (for example with data acquisition devices which are always sending data).
- No Primeiro Caso Sincrono
- 1. When a process calls read, the driver method allocates a DMA buffer and instructs the hardware to transfer its data. The process is put to sleep.
- 2. The hardware writes data to the DMA buffer and raises an interrupt when it's done.
- 3. The interrupt handler gets the input data, acknowledges the interrupt, and awakens the process, which is now able to read data.

Operating System Concepts

2.20





## **DMA Refs**

- Linux Device Drivers, 2nd Edition, Alessandro Rubini & Jonathan Corbet
  - http://www.xml.com/ldd/chapter/book/ch13.html
- WikiPedia
  - http://pt.wikipedia.org/wiki/Acesso\_direto\_à\_memória





#### **Armazenamento**

- A situação ideal
  - Programas e Dados localizados na memória principal
- Não é uma situação realística
  - Memoria Principal é geralmente demasiado pequena para guardar todos os programas e dados em memoria
  - Memoria Principal é "volatile"
  - ( Pode ser realística em sistemas especiais!)
- Memória Principal é demaisado longe do CPU (Von-Neumann Bottleneck)
- Portanto sistemas computacionais fornecem vários formas de memoria secundária



Operating System Concepts

2.23

Silberschatz, Galvin and Gagne ©2002



## Meios de Armazenamento

- Memória principal meio de armazenamento que só a CPU pode aceder directamente.
- Memória secundária extensão da memória principal que fornece uma grande capacidade de armazenamento não-volátil.
- Discos magnéticos pratos de vidro ou de metal rígido revestidos de material magnético de gravação
  - A superfície do disco está logicamente dividida em pistas (tracks), as quais pro sua vez estão divididas em sectores (sectors).
  - O controlador do disco determina a interacção lógica entre o dispositivo e o computador.

Disco Magnético

track t spindle arm assembly sector s spindle rotation

Silberschatz, Galvin and Gagne ©2002

Operating System Concepts



### Hierarquia de Armazenamento

- Hierarquia de armazenamento pode ser feita em termos:
  - Velocidade
  - Custo
  - Volatilidade
- Caching cópia de informação num sistema de armazenamento mais rápido; a memória principal pode ser vista como a última cache para o armazenamento secundário.
- Caching Utilização de memória de alta-velocidade para guardar os dados recentemente acedidos.
   Requer uma política de gestão de cache.



Hierarquia de memórias



Operating System Concepts

2.25

Silberschatz, Galvin and Gagne ©2002



## Protecção de Hardware

- Operação em modo dual (Dual-Mode)
- Protecção I/O
- Protecção de memória
- Protecção da CPU

A partilha de recursos do sistema requer que o sistema operativo assegure que um programa incorrecto não faça com que outros programas funcionem incorrectamente.

Exemplo: SO simples de Loteamento de Tarefas Imagine um programa incorrecto que entre num ciclo infinito a ler dados/instruções sucessivas (cartões perfurados). Poderia começar a ler os dados/instruções da próxima tarefa com resultados catastrophicos para o batch!

Solução: A Instrução "Load In Next Card" é priveligiado..



Operating System Concepts

2.26



## Operação em Dual-Mode

- Fornece suporte de hardware para <u>diferenciar</u> pelo menos dois modos de operação:
  - 1. *User mode* execução desencadeada pelo utilizador.
  - Monitor mode (ou kernel mode ou system mode ou bit mode) – execução desencadeada pelo sistema operativo.
- Quando uma interrupção ou excepção ocorre, o hardware comuta para o modo monitor.
- Implementação

um bit pode ser adicionado ao hardware do computador para indicar o modo corrente: monitor (0) ou utilizador (1) – chamado Mode Bit

Intel 8088 <u>intel 80286</u>

Operating System Concepts

Interrupt/fault



set user mode

*Instruções privilegiadas* só podem ser emitidas em modo monitor.

Arquitectura Intel 80486 mode bit → dual mode

SO - WINNT OS/2 Utilizem este facto – mais seguro!



Silberschatz, Galvin and Gagne ©2002





## Protecção I/O

- Todas as instruções I/O são instruções privilegiadas.
- Tem de assegurar que um programa do utilizador jamais pode adquirir controlo do computador em modo monitor (ou seja, um programa do utilizador que, durante a sua execução, armazena um novo endereço no vector de interrupções).



Chamada ao sistema para efectuar I/O

Operating System Concepts

2.29

Silberschatz, Galvin and Gagne ©2002





- Tem de fornecer protecção de memória pelo menos para o vector de interrupções e ISR's
- Para ter protecção de memória, adiciona-se dois registos que determinam a gama de endereços que um programa possa aceder:
  - Registo de base guarda o endereço mais baixo de memória física.
  - Registo limite –o tamanho da gama.
- Memória fora da gama está protegida.
- Sob execução em modo monitor, o sistema operativo tem acesso livre quer à memória do monitor quer à memória do utilizador.
- As instruções de carregamento dos registos de base e de limite são instruções privilegiadas.





Silberschatz, Galvin and Gagne ©2002

Operating System Concepts



### Protecção da CPU

- Qualquer programa n\u00e3o pode executar demaisado tempo!
  - Ciclo Infinito
  - Processamento Abusivo
- Assegurar que o SO MANTÊM "controlo"
- Timer interrompe o computador após período especificado.
  - O timer é decrementado por cada batida (tick) do relógio.
  - Quando o timer atinge o valor 0, ocorre uma interrupção.
- O Timer é usado para assegurar que um SO possa manter controlo e para implementar time-sharing.
- *Timer* é também usado para calcular o tempo corrente.
- Load-timer é uma instrução privilegiada.

FIM DE CAPÍTULO

Operating System Concepts

Silberschatz, Galvin and Gagne ©2002



## Pergunta 1

- Protecting the operating system is crucial to ensuring that the computer system operates correctly. Provision of this protection is the reason behind dual-mode operation, memory protection, and the timer. To allow maximum flexibility, however, we would also like to place minimal constraints on the user.
- The following is a list of operations that are normally protected. What is the *minimal* set of instructions that must be protected?
- a. Change to user mode.
- b. Change to monitor mode.
- c. Read from monitor memory.
- d. Write into monitor memory.
- e. Fetch an instruction from monitor memory.
- f. Turn on timer interrupt.
- g. Turn off timer interrupt.



Operating System Concepts



## Pergunta 2

- Which of the following instructions should be privileged?
- a. Set value of timer.
- b. Read the clock.
- c. Clear memory.
- d. Issue a trap instruction.
- e. Turn off interrupts.
- f. Modify entries in device-status table.
- g. Switch from user to kernel mode.
- h. Access I/O device.



Operating System Concepts

2.33

Silberschatz, Galvin and Gagne ©2002



## Pergunta 3

Some CPUs provide for more than two modes of operation. What are two possible uses of these multiple modes?

Answer:. Multiple

modes could be used to provide a finer-grained security policy. For example, rather than distinguishing between just user and kernelmode, you could distinguish between different types of user mode. Perhaps users belonging to the same group could execute each other's code. The machine would go into a specified mode when one of these users was running code. When the machine was in this mode, a member of the group could run code belonging to anyone else in the group.

Another possibility would be to provide different distinctions within kernel code. For example, a specific mode could allow USB device drivers to run. This would mean that USB devices could be serviced without having to switch to kernel mode, thereby essentially allowing USB device drivers to run in a quasi-user/kernel mode.

