Вы находитесь на странице: 1из 5

Faculdade de Tecnologia, Universidade de Brasília, Campus Universitário Darcy Ribeiro, Gleba A, Avenida L3 Norte, CEP 70.

910-900, Brasília-DF
Caixa Postal 4386, fone +55 61 3307 2300, fone/fax +55 61 3273 8893, ftd@unb.br, www.ft.unb.br

Lista de exercícios 2 – Sistemas Operacionais de Rede



1. Como seria utilizar um computador sem um sistema operacional? Quais são suas duas principais funções?
Resp.: Sem o sistema operacional, um usuário para interagir com o computador deveria conhecer
profundamente diversos detalhes sobre hardware do equipamento, o que tornaria seu trabalho lento e
com grandes possibilidades de erros. As duas principais funções do sistema operacional são:
“facilidade de acesso aos recursos do sistema” e “compartilhamento de recursos de forma organizada
e protegida”.

2. Por que dizemos que existe uma subutilização de recursos em sistemas monoprogamáveis? Qual a grande
diferença entre sistemas monoprogramáveis e sistemas multiprogramáveis?
Resp.: Porque em sistemas monoprogramáveis somente é possível a execução de um programa por
vez. Como um programa não utiliza todos os recursos do sistema totalmente ao longo da sua execução,
existe ociosidade e, consequentemente, subutilização de alguns recursos.

3. O que é concorrência e como este conceito está presente nos sistemas operacionais multiprogramáveis?
Resp.: Concorrência é o princípio básico para projeto e implementação dos sistemas operacionais
multiprogramáveis onde é possível o processador executar instruções em paralelo com operações de
E/S. Isso possibilita a utilização concorrente da UCP por diversos programas sendo implementada de
maneira que, quando um programa perde o uso do processador e depois retorna para continuar o
processamento, seu estado deve ser idêntico ao do momento em que foi interrompido. O programa
deverá continuar sua execução exatamente na instrução seguinte àquela em que havia parado,
aparentando ao usuário que nada aconteceu.

4. Explique o mecanismo de funcionamento das interrupções.


Resp.: Uma interrupção é sempre gerada por algum evento externo ao programa e, neste caso,
independe da instrução que está sendo executada. Ao final da execução de cada instrução, a unidade
de controle verifica a ocorrência de algum tipo de interrupção. Neste caso, o programa em execução é
interrompido e o controle desviado para uma rotina responsável por tratar o evento ocorrido,
denominada rotina de tratamento de interrupção. Para que o programa possa posteriormente voltar a
ser executado, é necessário que, no momento da interrupção, um conjunto de informações sobre a sua
execução seja preservado. Essas informações consistem no conteúdo de registradores, que deverão ser
restaurados para a continuação do programa.

5. Qual a vantagem da E/S controlada por interrupção comparada com a técnica de polling (ou programada)?
Resp.: Na E/S controlada por interrupção, as operações de E/S podem ser realizadas de uma forma
mais eficiente. Em vez de o sistema periodicamente verificar o estado de uma operação pendente como
na técnica de polling, o próprio controlador interrompe o processador para avisar do término da
operação. Com esse mecanismo, o processador, após a execução de um comando de leitura ou
gravação, permanece livre para o processamento de outras tarefas.

6. O que é DMA e qual a vantagem desta técnica?


Resp.: A técnica de DMA permite que um bloco de dados seja transferido entre a memória principal e
dispositivos de E/S, sem a intervenção do processador, exceto no início e no final da transferência.
Quando o sistema deseja ler ou gravar um bloco de dados, o processador informa ao controlador sua
localização, o dispositivo de E/S, a posição inicial da memória de onde os dados serão lidos ou
gravados e o tamanho do bloco. Com estas informações, o controlador realiza a transferência entre o
periférico e a memória principal, e o processador é somente interrompido no final da operação.

7. Por que a questão da proteção torna-se fundamental em ambientes multiprogramáveis?


Faculdade de Tecnologia, Universidade de Brasília, Campus Universitário Darcy Ribeiro, Gleba A, Avenida L3 Norte, CEP 70.910-900, Brasília-DF
Caixa Postal 4386, fone +55 61 3307 2300, fone/fax +55 61 3273 8893, ftd@unb.br, www.ft.unb.br

Resp.: Se considerarmos que diversos usuários estão compartilhando os mesmos recursos como
memória, processador e dispositivos de E/S, deve existir uma preocupação em garantir a
confiabilidade e a integridade dos programas e dados dos usuários, além do próprio sistema
operacional.

8. O que é o núcleo do sistema e quais são suas principais funções?


Resp.: É o conjunto de rotinas que oferece serviços aos usuários, suas aplicações, além do próprio
sistema operacional. As principais funções do núcleo encontradas na maioria dos sistemas comerciais
são: tratamento de interrupções e exceções; criação e eliminação de processos e threads; sincronização
e comunicação entre processos e threads; escalonamento e controle dos processos e threads; gerência
de memória; gerência do sistema de arquivos; gerência de dispositivos de E/S; suporte à redes locais e
distribuídas; contabilização do uso do sistema; auditoria e segurança do sistema.

9. O que é uma system call e qual sua importância para a segurança do sistema? Como as system calls são
utilizadas por um programa?
Resp.: As system calls podem ser entendidas como uma porta de entrada para o acesso ao núcleo do
sistema operacional e a seus serviços. Sempre que um usuário ou aplicação desejar algum serviço do
sistema, é realizada uma chamada a uma de suas rotinas através de uma system call. Através dos
parâmetros fornecidos na system call, a solicitação é processada e uma resposta é retornada a
aplicação juntamente com um estado de conclusão indicando se houve algum erro. O mecanismo de
ativação e comunicação entre o programa e o sistema operacional é semelhante ao mecanismo
implementado quando um programa chama uma subrotina.

10. Explique como funciona a mudança de modos de acesso e dê um exemplo de como um programa faz uso
desse mecanismo.
Resp.: Sempre que um programa necessita executar uma instrução privilegiada, a solicitação deve ser
realizada através de uma chamada a uma system call, que altera o modo de acesso do processador do
modo usuário para o modo kernel. Ao término da execução da rotina do sistema, o modo de acesso
retorna para o modo usuário.

11. Defina o conceito de processo.


Resp.: Um processo pode ser definido como o ambiente onde um programa é executado. Este
ambiente, além das informações sobre a execução, possui também o quanto de recursos do sistema
cada programa pode utilizar, como o espaço de endereçamento, tempo de processador e área em disco.

12. Por que o conceito de processo é tão importante no projeto de sistemas multiprogramáveis?
Resp.: Através de processos, um programa pode alocar recursos, compartilhar dados, trocar
informações e sincronizar sua execução. Nos sistemas multiprogramáveis os processos são executados
concorrentemente, compartilhando o uso do processador, memória principal, dispositivos de E/S
dentre outros recursos.

13. É possível que um programa execute no contexto de um processo e não execute no contexto de um outro?
Por que?
Resp.: Sim, pois a execução de um programa pode necessitar de recursos do sistema que um processo
pode possuir enquanto outro não.

14. Quais partes compõem um processo?


Resp.: Um processo é formado por três partes, conhecidas como contexto de hardware, contexto de
software e espaço de endereçamento, que juntos mantêm todas as informações necessárias à execução
de um programa.

15. O que é uma troca de contexto? Como e quando ela ocorre?


Faculdade de Tecnologia, Universidade de Brasília, Campus Universitário Darcy Ribeiro, Gleba A, Avenida L3 Norte, CEP 70.910-900, Brasília-DF
Caixa Postal 4386, fone +55 61 3307 2300, fone/fax +55 61 3273 8893, ftd@unb.br, www.ft.unb.br

Resp.: O contexto de hardware armazena o conteúdo dos registradores gerais da UCP, além dos
registradores de uso específico como program counter (PC), stack pointer (SP) e registrador de status.
Quando um processo está em execução, o seu contexto de hardware está armazenado nos registradores
do processador. No momento em que o processo perde a utilização da UCP, o sistema salva as
informações no contexto de hardware do processo.

16. O que é o espaço de endereçamento de um processo?


Resp.: O espaço de endereçamento é a área de memória pertencente ao processo onde as instruções e
dados do programa são armazenados para execução. Cada processo possui seu próprio espaço de
endereçamento, que deve ser devidamente protegido do acesso dos demais processos.

17. Como o sistema operacional implementa o conceito de processo? Qual a estrutura de dados indicada para
organizar os diversos processos na memória principal?
Resp.: O processo é implementado pelo sistema operacional através de uma estrutura de dados
chamada bloco de controle do processo (Process Control Block — PCB). A partir do PCB, o sistema
operacional mantém todas as informações sobre o contexto de hardware, contexto de software e
espaço de endereçamento de cada processo.

18. Desenhe o diagrama clássico (de 5 estágios) de processos. Explique todas as transições.
R: Vejam nos slides.

19. O que são processos CPU-bound e I/O-bound?


Resp.: Processos CPU-bound usam a CPU com mais frequência e por mais tempo, enquanto processos
I/O-bound fazem I/O com mais frequência e por mais tempo.

20. Como funciona a chamada de sistema fork() de sistemas do tipo UNIX? Dê um exemplo de uso com um
programa em C.
Resp.: A chama fork() cria um processo que é a cópia do pai, ou seja, seu contexto é igual ao do pai.
No processo pai, a chamada fork retorna um número inteiro positivo que corresponde ao PID do
processo filho criado, enquanto que no processo filho, a chamada fork retorna zero. Esta é a maneira
de saber, dentro do programa, o que fazer para o pai e para o filho depois da chamada. Exemplos de
uso se encontram no site.

21. Qual a função da chamada exec() de sistemas do tipo UNIX? Dê um exemplo de uso com um programa em
C.
Resp.: A chamada exec troca a área de texto do processo, ou seja, altera o programa a ser executado.
Geralmente é usada em conjunto com a chamada fork quando se deseja chamar a execução de um
programa à partir de outro. Exemplos de uso se encontram no site.

22. Qual a função das chamadas shmget(), shmst() e shmdt() de sistemas do tipo UNIX? Dê um exemplo de uso
com um programa em C.
R: As chamadas shmged, shmat e shmdt, respectivamente, cria/obtém uma região de memória
compartilhada, anexa a região ao espaço de endereçamento do processo e desanexa a região do espaço
de endereçamento do processo. Exemplos de uso se encontram no site.

23. O que são pipes? Dê um exemplo de uso da chamada pipe() dos sistemas do tipo UNIX com um programa
em C.
Resp.: Pipes permitem que dois processos comuns se comuniquem na forma de produtor consumidor.
Exemplos do uso de pipes se encontram nos slides.

24. Defina o conceito de thread.


Faculdade de Tecnologia, Universidade de Brasília, Campus Universitário Darcy Ribeiro, Gleba A, Avenida L3 Norte, CEP 70.910-900, Brasília-DF
Caixa Postal 4386, fone +55 61 3307 2300, fone/fax +55 61 3273 8893, ftd@unb.br, www.ft.unb.br

R: Uma thread é uma linha de execução do programa, ou seja, o conjunto de informações de software
e hardware (ex: registradores Program Counter, Stack, etc.) que, juntos, definem a execução do
programa. Em geral, todo processo inicia sua execução a partir de uma thread, podendo criar e
executar mais threads. Todas as threads compartilham o mesmo espaço de endereçamento do processo
que as originou.

25. Quais partes compõem uma thread?


R: Uma thread é composta pelo mesmo conjunto de informações (contexto de software e de hardware)
que juntos, definem o processo. A única diferença é que todas as threads compartilham o mesmo
espaço de endereçamento do processo que as originou.

26. Explique os três tipos de modelo de geração e gerenciamento de threads.


R: As threads podem ser criadas no modo usuário ou no modo kernel, sendo neste último caso
conhecidas como “threads do kernel” e gerenciadas pelo sistema operacional. As threads de kernel
tem um custo de criação e de troca de contexto um pouco mais elevados do que as threads de usuário.
No entanto, as threads de kernel usam o hardware de maneira mais eficiente e podem ser alocadas aos
diversos núcleos disponíveis no processador. As threads podem ser criadas e gerenciadas segundo os
modelos Muitos-para-um, Um-para-um e Muitos-para-muitos, sendo o modelo um-para-um o mais
frequentemente implementado e usado pelos sistemas operacionais modernos. No modelo muitos-para-
um, cada thread no espaço do usuário é gerenciada por uma thread no espaço do kernel. Deste modo,
se uma thread de usuário fizer uma operação de E/S, todas as demais threads também serão
bloqueadas, já que a thread de kernel sofrerá uma troca de contexto, levando consigo todas as demais.
No modelo um-para-um, cada thread de usuário é gerenciada por uma thread de kernel e, portanto,
são independentes umas das outras. Por fim, no modelo muitos-para-muitos, um conjunto de threads
de usuário é gerenciada por um conjunto de threads de kernel.

27. Qual a diferença entre Processos e Threads? Explique.


R: A diferença entre Processos e Threads é muito sutil. As Threads nada mais são que diferentes
linhas de execução do mesmo programa e que, portanto, enxergam o mesmo espaço de endereçamento.
O contexto de software e hardware de uma thread é menor que o de um processo e, por isso, a troca de
contexto de threads costuma ser mais rápida e eficiente.

28. Como funciona a chamada POSIX threads para criação de threads? Dê um exemplo de uso com um
programa em C.

#include <pthread.h>
#include <stdio.h>
#define NUM_THREADS 5

int x[NUM_THREADS];

void *print_hello(void *threadId)


{
long tid;
tid = (long) threadId;
x[tid]++;
printf("Hello World %d! Sou eu, thread %ld!\n",x,tid);
pthread_exit(NULL);
}
Faculdade de Tecnologia, Universidade de Brasília, Campus Universitário Darcy Ribeiro, Gleba A, Avenida L3 Norte, CEP 70.910-900, Brasília-DF
Caixa Postal 4386, fone +55 61 3307 2300, fone/fax +55 61 3273 8893, ftd@unb.br, www.ft.unb.br

int main(int argc, char **argv)


{
for(int i = 0 ; i < NUM_THREADS; i++)
x[i] = 0;

pthread_t threads[NUM_THREADS];

int rc;
long t;

for(t = 0 ; t < NUM_THREADS ; t++)


{
printf("Main: criando thread %ld\n",t);
rc = pthread_create(&threads[t],NULL,print_hello, (void*) t);
if(rc)
{
fprintf(stderr,"erro %d ao criar thread\n",rc);
return -1;
}
}

pthread_exit(NULL);

Вам также может понравиться