Funzioni di libreria. user programs libraries. process control subsystem. character block device drivers. system call interface.
|
|
|
- Giuditta Assunta Mura
- 10 anni fa
- Visualizzazioni
Transcript
1 1
2 Funzioni di libreria user Level kernel Level trap user programs libraries system call interface file subsystem buffer cache character block device drivers process control subsystem hardware control inter-process communication scheduler memory management hardware 29
3 System call per utilizzare i servizi del s.o., il programmatore ha a disposizione una serie di entry point per il kernel chiamate system calls: in UNIX, circa , a seconda della versione. nei sistemi UNIX, ogni system call corrisponde ad un funzione di libreria C: il programmatore chiama la funzione, utilizzando la sequenza di chiamata standard di C; la funzione invoca il servizio del sistema operativo nel modo più opportuno. 2
4 Funzioni di libreria: funzioni di utilità che forniscono servizi general purpose al programmatore; queste funzioni non sono entry point del kernel, sebbene alcune di esse possano fare uso delle system call per realizzare i propri servizi. esempi: La funzione printf può invocare la system call write per stampare. La funzione strcpy (string copy) e la funzione atoi (convert ASCII to integer) non coinvolgono il sistema operativo. 3
5 Distinzione: Dal punto di vista del programmatore, non vi sono grosse distinzioni fra le funzioni di libreria e le system call: Entrambe sono funzioni. Dal punto di vista di chi implementa un sistema operativo, la differenza è ovviamente più importante. Nota: E possibile sostituire le funzioni di libreria con altre funzioni che realizzino lo stesso compito, magari in modo diverso; In generale, non è possibile sostituire le system call, che dipendono dal sistema operativo. 4
6 Le funzioni malloc, free gestiscono l allocazione della memoria e le procedure associate di garbage collection; esistono diversi modi per implementare la malloc e la free (best fit, first fit, worst fit, etc); è possibile sostituire la malloc con il nostro meccanismo di allocazione. La system call sbrk: non è una funzione di allocazione della memoria general-purpose; il suo unico compito è di aumentare o diminuire lo spazio di memoria associato ad un processo. 5
7 #include <unistd.h> void *sbrk(intptr_t increment); sbrk() increments the program's data space by increment bytes.
8 ntroduzione La funzione malloc (e qualunque funzione alternativa per la gestione della memoria) è basata sulla sbrk: application code memory allocation function malloc user process sbrk kernel 6
9 POSIX (Portable Operating System Interface) E una famiglia di standard sviluppato dall IEEE IEEE (POSIX.1) Definizione delle system call (operating system interface) IEEE (POSIX.2) Shell e utility IEEE (POSIX.7) System administration Noi siamo interessati allo standard IEEE (POSIX.1) POSIX Original standard POSIX Revised text POSIX.1a 1993 Addendum POSIX.1b 1993 Real-time extensions POSIX.1c 1996 Thread extensions Alberto Montresor, Renzo Davoli 7
10 Supporto allo standard POSIX Fully compliant BSD/OS HP-UX LynxOS Mac OS X MINIX Solaris UnixWare Mostly compliant BeOS / Haiku FreeBSD GNU/Linux NetBSD OpenBSD OpenSolaris POSIX for Windows Cygwin Microsoft POSIX subsystem Microsoft Windows Services for UNIX 3.5 UWIN from the AT&T
11 POSIX ha lo scopo di rendere le applicazioni tra diversi sistemi. Descrive I punti di contatto con il kernel ma non come questi vengano implementati effettivamente. Lo standard è definito a livello di codice sorgente: Standard C (tipico) Altri linguaggi (ADA, FORTRAN) Non descrive aspetti specifici del sistema operativo ma offre solo funzioni ordinarie che le applicazioni includono. POSIX può sfruttare sia il C tradizionale che lo Standard C (ANSI C). Assumeremo che lo Standard C sia preso come riferimento.
12 POSIX.1 cpio.h valori di archivio x cpio dirent.h gestione directory fcntl.h controllo dei file grp.h gestione del file group pwd.h gestione del file password tar.h valori di archivio x tar termios.h I/O terminale unistd.h costanti simboliche utime.h informazioni sul tempo / file sys/stat.h informazioni sui file sys/times.h informazioni sul tempo / processi sys/types.h tipi di dato di sistema sys/wait.h controllo processi Alberto Montresor, Renzo Davoli 8
13 System calls Sono l interfaccia programmativa verso il kernel, per richiedere i servizi del kernel. Il loro numero dipende dalla versione di Unix (da una settantina a oltre 200). Le categorie principali di system call sono tre: Input/output Process management Inter-process communications open, close, read, fork, exec, exit, kill, send, pipe, socket, write, 11
14 POSIX.1 include anche alcune primitive della C Standard Library Numero di funzioni: Esempio: C Standard Library Posix open() è POSIX fopen() è Standard C e POSIX sin() è Standard C Alberto Montresor, Renzo Davoli 9
15 Per scrivere un programma conforme a POSIX, bisogna includere gli header files richiesti dalle varie primitive usate, scelti fra: header files della C Standard Library (contenenti opportune modifiche POSIX) header files specifici POSIX Nel seguito, gli header files saranno omessi dalle slide; Inoltre: per ottenere la lista completa degli header necessari, utilizzate man. Se vogliamo compilare un programma in modo tale che dipenda solo dallo standard POSIX, dobbiamo inserire prima degli #include: #define _POSIX_SOURCE Alberto Montresor, Renzo Davoli 10
16 Tipi di dato Storicamente, le variabili UNIX sono state associate a certi tipi di dato C ad esempio: nel passato, i major/minor device number sono stati collocati un variabile a 16 bit (8 major, 8 minor); sistemi più grandi possono richiedere una dimensione maggiori (e.g. SVR4 usa 32 bit, 14 major, 18 minor). Lo header sys/types.h definisce i tipi dei dati di sistema primitivi (dipendenti dall implementazione): ad esempio, in linux sys/types.h definisce il tipo dev_t come una quantità a 16 bit; questi tipi sono definiti per garantire portabilità; sono definiti tramite typedef. to Montresor, Renzo Davoli 11 r
17 Alcuni dei primitive system data types clock_t counter of clock ticks dev_t device numbers fd_set file descriptor set fpos_t file position gid_t group id ino_t inode number mode_t file types, file creation mode nlink_t number of hard links off_t offset pid_t process id size_t dimensioni (unsigned) ssize_t count of bytes (signed) (read, write) time_t counter of seconds since the Epoch uid_t user id Alberto Montresor, Renzo Davoli 12
18 Limiti delle implementazioni UNIX esistono un gran numero di valori costanti e magic number che dipendono dall implementazione di UNIX; nel passato, questi valori erano hard-coded nei programmi (i valori venivano inseriti direttamente); per garantire una maggior portabilità, i vari standard hanno definito dei metodi più portabili per accedere alle costanti specifiche di un implementazione. lberto Montresor, Renzo Davoli 13 A
19 Si considerano tre classi di valori costanti: Note: opzioni compile-time (il sistema supporta job control?) limiti compile-time (quant è il valore massimo per short?) limiti run-time (quanti caratteri in un nome di file?) le prime due classi sono determinate a tempo di compilazione, e quindi i loro valori possono essere definiti come costanti negli header di POSIX/ANSI C; la terza classe richiede che il valore sia ottenuto chiamando un opportuna funzione Alberto Montresor, Renzo Davoli 14 01
20 Limiti ANSI-C tutti i limiti ANSI C sono limiti compile-time; sono definiti nello header limits.h (/usr/include/limits.h) contiene informazioni sui tipi primitivi, come ad esempio numero di bit in un char valore massimi/minimi di char, signed char, unsigned char, int, unsigned int, short, unsigned short, long, unsigned long Alberto Montresor, Renzo Davoli 15
21 Limiti POSIX.1 POSIX.1 definisce un gran numero di costanti che definiscono limiti implementativi del sistema operativo; questo è uno degli aspetti più complessi di POSIX.1. Limiti runtime alcuni limiti runtime possono essere fissi in un implementazione; altri possono variare all interno della stessa implementazione; esempio: la dimensione massima di nome di file dipende dal particolare file system considerato Alberto Montresor, Renzo Davoli 16 0
22 33 limiti e costanti, suddivisi in 7 categorie: valori minimi invarianti (13 costanti definite in limits.h) questi valori non cambiano da un sistema ad un altro. rappresentano i valori minimi che devono essere supportati da qualunque implementazione POSIX _POSIX_ARG_MAX number of arguments 4096 _POSIX_CHILD_MAX number of child processes per uid 6 _POSIX_LINK_MAX number of links to a file 8... nota: limiti troppo bassi per essere significativi. limiti invarianti: SSIZE_MAX max size of type ssize limiti che possono crescere a run-time: NGROUPS_MAX max n. of gids associated to a process Alberto Montresor, Renzo Davoli 17
23 3 Limiti invarianti run-time (eventualmente indeterminati): ARG_MAX max. number of arguments for exec CHILD_MAX max. number of processes per user ID CLK_TCK number of clocks ticks per second OPEN_MAX max number of open files per process PASS_MAX max. number of significant char. in password STREAM_MAX max. number of standard I/O streams TZNAME_MAX max. number of byte for names of a time zone Costanti simboliche a tempo di compilazione: _POSIX_SAVED_IDS if implementations supports saved ids _POSIX _VERSION posix version _POSIX _JOB_CONTROL if implementations supports job control Alberto Montresor, Renzo Davoli 18
24 limiti variabili per i pathname (eventualmente indeterm.): LINK_MAX MAX_CANON MAX_INPUT NAME_MAX PATH_MAX PIPE_BUF max value of link s count terminal-related terminal-related max number of chars for a filename (no-null) max number of chars for a pathname (no-null) max. number of bytes atomic. written in a pipe flag variabili: _POSIX_NO_TRUNC if filenames longer than NAME_MAX are truncated _POSIX_CHOWN_RESTRICTED if use of chown is restricted Alberto Montresor, Renzo Davoli 19
25 Funzioni di lettura limiti: long sysconf(int name); long pathconf(const char *path, int name); long fpathconf(int filedes, int name) La prima legge i valori invarianti esempio di nome: _SC_nome costante La seconda e la terza leggono i valori che possono variare a seconda del file a cui sono applicati esempio di nome: _PC_nome_costante (Vedi codice contenuto in conf.c) Alberto Montresor, Renzo Davoli 20
26 Limiti indeterminati se non è definito nello header limits.h se sysconfig() o pathconfig() ritornano 1 allora il valore non è definito Esempio: molti programmi hanno necessità di allocare spazio per i pathname; la domanda è: quanto? in caso il valore di default non sia sufficiente, in alcuni casi è possibile aumentare lo spazio previsto e ritentare Alberto Montresor, Renzo Davoli 21
27 La maggior parte delle system call: restituisce il valore -1 in caso di errore ed assegna lo specifico codice di errore alla variabile globale extern int errno; Nota: se la system call ha successo, errno non viene resettato Lo header file errno.h contiene la definizione dei nomi simbolici dei codici di errore # define EPERM 1 /* Not owner */ # define ENOENT 2 /* No such file or dir */ # define ESRCH 3 /* No such process */ # define EINTR 4 /* Interr. system call */ # define EIO 5 /* I/O error */ Alberto Montresor, Renzo Davoli 22
28 void perror (const char *str ) converte il codice in errno in un messaggio in inglese, e lo stampa anteponendogli il messaggio di errore str Esempio:... fd=open("nonexist.txt", O_RDONLY); if (fd==-1) perror ("main");... --> main: No such file or directory Alberto Montresor, Renzo Davoli 23
Laboratorio di Sistemi Operativi
II Semestre - Marzo/Giugno 2008 Matricole congr. 0 mod 3 File & Directory #include #include stat,fstat e lstat int stat (const char *pathname, struct stat *buf); int fstat (int
I/O su Socket TCP: read()
I/O su Socket TCP: read() I socket TCP, una volta che la connessione TCP sia stata instaurata, sono accedibili come se fossero dei file, mediante un descrittore di file (un intero) ottenuto tramite una
Fondamenti di Informatica e Laboratorio T-AB T-16 Progetti su più file. Funzioni come parametro. Parametri del main
Fondamenti di Informatica e Laboratorio T-AB T-16 Progetti su più file. Funzioni come parametro. Parametri del main Paolo Torroni Dipartimento di Elettronica, Informatica e Sistemistica Università degli
Dynamic Linking. Introduzione Creazione di una libreria dinamica Uso di una libreria dinamica
Dynamic Linking Introduzione Creazione di una libreria dinamica Uso di una libreria dinamica Dynamic Linking Il linking tra i moduli di un programma e le librerie da esso utilizzate può essere Statico
Drivers. Introduzione Tipologie Struttura Interazione con il kernel
Drivers Introduzione Tipologie Struttura Interazione con il kernel Driver Un driver è un modulo del sistema operativo Esterno al kernel Dedicato alla gestione di una specifica periferica Come altre funzionalità
Sistemi Operativi. Interfaccia del File System FILE SYSTEM : INTERFACCIA. Concetto di File. Metodi di Accesso. Struttura delle Directory
FILE SYSTEM : INTERFACCIA 8.1 Interfaccia del File System Concetto di File Metodi di Accesso Struttura delle Directory Montaggio del File System Condivisione di File Protezione 8.2 Concetto di File File
Sistemi Operativi. Processi GESTIONE DEI PROCESSI. Concetto di Processo. Scheduling di Processi. Operazioni su Processi. Processi Cooperanti
GESTIONE DEI PROCESSI 4.1 Processi Concetto di Processo Scheduling di Processi Operazioni su Processi Processi Cooperanti Concetto di Thread Modelli Multithread I thread in diversi S.O. 4.2 Concetto di
Sistemi Operativi MECCANISMI E POLITICHE DI PROTEZIONE. D. Talia - UNICAL. Sistemi Operativi 13.1
MECCANISMI E POLITICHE DI PROTEZIONE 13.1 Protezione Obiettivi della Protezione Dominio di Protezione Matrice di Accesso Implementazione della Matrice di Accesso Revoca dei Diritti di Accesso Sistemi basati
MECCANISMI E POLITICHE DI PROTEZIONE 13.1
MECCANISMI E POLITICHE DI PROTEZIONE 13.1 Protezione Obiettivi della Protezione Dominio di Protezione Matrice di Accesso Implementazione della Matrice di Accesso Revoca dei Diritti di Accesso Sistemi basati
Sistemi Operativi IMPLEMENTAZIONE DEL FILE SYSTEM. D. Talia - UNICAL. Sistemi Operativi 9.1
IMPLEMENTAZIONE DEL FILE SYSTEM 9.1 Implementazione del File System Struttura del File System Implementazione Implementazione delle Directory Metodi di Allocazione Gestione dello spazio libero Efficienza
Struttura di un sistema operativo. Struttura dei Sistemi Operativi. Servizi per l utente generico. Servizi per l utente generico
Impossibile visualizzare l'immagine. Struttura di un sistema operativo Struttura dei Sistemi Operativi Servizi di un sistema operativo Interfaccia Utente Capitolo 2 -- Silberschatz Chiamate di sistema
Sistemi Operativi IMPLEMENTAZIONE DEL FILE SYSTEM. Implementazione del File System. Struttura del File System. Implementazione
IMPLEMENTAZIONE DEL FILE SYSTEM 9.1 Implementazione del File System Struttura del File System Implementazione Implementazione delle Directory Metodi di Allocazione Gestione dello spazio libero Efficienza
Capitolo 2 -- Silberschatz
Struttura dei Sistemi Operativi Capitolo 2 -- Silberschatz Struttura di un sistema operativo Servizi di un sistema operativo Interfaccia Utente Chiamate di sistema Tipi di chiamate Programma di sistema
File system II. Sistemi Operativi Lez. 20
File system II Sistemi Operativi Lez. 20 Gestione spazi su disco Esiste un trade-off,tra spreco dello spazio e velocità di trasferimento in base alla dimensione del blocco fisico Gestione spazio su disco
Il Software. Il software del PC. Il BIOS
Il Software Il software del PC Il computer ha grandi potenzialità ma non può funzionare senza il software. Il software essenziale per fare funzionare il PC può essere diviso nelle seguenti componenti:
Chiamate di sistema per la Gestione dei processi in POSIX. E.Mumolo, DEEI [email protected]
Chiamate di sistema per la Gestione dei processi in POSIX E.Mumolo, DEEI [email protected] Process id ed altri identificatori pid_t getpid(); // Process id del processo chiamante pid_t getppid(); // Process
Introduzione alla programmazione in C
Introduzione alla programmazione in C Testi Consigliati: A. Kelley & I. Pohl C didattica e programmazione B.W. Kernighan & D. M. Ritchie Linguaggio C P. Tosoratti Introduzione all informatica Materiale
Protezione. Protezione. Protezione. Obiettivi della protezione
Protezione Protezione La protezione riguarda i meccanismi per il controllo dell accesso alle risorse in un sistema di calcolo da parte degli utenti e dei processi. Meccanismi di imposizione fissati in
Linguaggio C. Fondamenti. Struttura di un programma.
Linguaggio C Fondamenti. Struttura di un programma. 1 La storia del Linguaggio C La nascita del linguaggio C fu dovuta all esigenza di disporre di un Linguaggio ad alto livello adatto alla realizzazione
ToolChain: Come Generare Applicazioni in Linguaggio Macchina
ToolChain: Come Generare Applicazioni in Linguaggio Macchina Luca Abeni e Luigi Palopoli March 30, 2015 La Lingua della CPU Una CPU capisce e riesce ad eseguire solo il linguaggio macchina Linguaggio di
12. Implementazione di un File System. 12.1.1 Struttura a livelli. 12.2.1 Allocazione contigua
12. Implementazione di un File System 1 Struttura del file system Metodi di allocazione Gestione dello spazio libero Implementazione delle directory Prestazioni ed efficienza 2 Utente 12.1.1 Struttura
Organizzazione Monolitica
Principali componenti di un sistema Applicazioni utente Interprete di comandi (shell) Interfaccia grafica (desktop) Gestore del processore / Scheduler(s) Gestore della memoria Gestore delle periferiche/
dall argomento argomento della malloc()
Allocazione dinamica Quando? Tutte le volte in cui i dati possono crescere in modo non prevedibile staticamente a tempo di sviluppo Un array con dimensione i fissata a compile-time non è sufficiente È
AXO. Operativo. Architetture dei Calcolatori e Sistema. programmazione di sistema
AXO Architetture dei Calcolatori e Sistema Operativo programmazione di sistema Il sistema operativo Il Sistema Operativo è un insieme di programmi (moduli software) che svolgono funzioni di servizio nel
Corso di Sistemi di Elaborazione delle informazioni
Corso di Sistemi di Elaborazione delle informazioni Sistemi Operativi Francesco Fontanella Complessità del Software Software applicativo Software di sistema Sistema Operativo Hardware 2 La struttura del
Capitolo 11 -- Silberschatz
Implementazione del File System Capitolo 11 -- Silberschatz Implementazione del File System File system: Definizione dell aspetto del sistema agli occhi dell utente Algoritmi e strutture dati che permettono
Modello dei processi. Riedizione delle slide della Prof. Di Stefano
Modello dei processi Riedizione delle slide della Prof. Di Stefano 1 Processi Modello di Processi asincroni comunicanti Process Scheduling Operazioni sui Processi Cooperazione tra Processi Interprocess
Il Sistema Operativo (1)
E il software fondamentale del computer, gestisce tutto il suo funzionamento e crea un interfaccia con l utente. Le sue funzioni principali sono: Il Sistema Operativo (1) La gestione dell unità centrale
Computazione multi-processo. Condivisione, Comunicazione e Sincronizzazione dei Processi. Segnali. Processi e Threads Pt. 2
Computazione multi-processo Avere più processi allo stesso momento implica/richiede Processi e Threads Pt. 2 Concorrenza ed efficienza Indipendenza e protezione dei dati ma deve prevedere/permettere anche:
I puntatori e l allocazione dinamica di memoria
I puntatori e l allocazione dinamica di memoria L allocazione delle variabili Allocazione e rilascio espliciti di memoria Le funzioni malloc e free 2 2006 Politecnico di Torino 1 Allocare = collocare in
Sistema operativo: Gestione della memoria
Dipartimento di Elettronica ed Informazione Politecnico di Milano Informatica e CAD (c.i.) - ICA Prof. Pierluigi Plebani A.A. 2008/2009 Sistema operativo: Gestione della memoria La presente dispensa e
Le operazioni di allocazione e deallocazione sono a carico del sistema.
Allocazione della memoria In C++ è possibile creare (allocare) variabili in maniera statica o dinamica. Nell allocazione statica una variabile esiste ed è utilizzabile dal momento della sua dichiarazione
Mac Application Manager 1.3 (SOLO PER TIGER)
Mac Application Manager 1.3 (SOLO PER TIGER) MacApplicationManager ha lo scopo di raccogliere in maniera centralizzata le informazioni piu salienti dei nostri Mac in rete e di associare a ciascun Mac i
ASPETTI GENERALI DI LINUX. Parte 2 Struttura interna del sistema LINUX
Parte 2 Struttura interna del sistema LINUX 76 4. ASPETTI GENERALI DEL SISTEMA OPERATIVO LINUX La funzione generale svolta da un Sistema Operativo può essere definita come la gestione dell Hardware orientata
Scheduling della CPU. Sistemi multiprocessori e real time Metodi di valutazione Esempi: Solaris 2 Windows 2000 Linux
Scheduling della CPU Sistemi multiprocessori e real time Metodi di valutazione Esempi: Solaris 2 Windows 2000 Linux Sistemi multiprocessori Fin qui si sono trattati i problemi di scheduling su singola
Tipi primitivi. Ad esempio, il codice seguente dichiara una variabile di tipo intero, le assegna il valore 5 e stampa a schermo il suo contenuto:
Tipi primitivi Il linguaggio Java offre alcuni tipi di dato primitivi Una variabile di tipo primitivo può essere utilizzata direttamente. Non è un riferimento e non ha senso tentare di istanziarla mediante
LINGUAGGI DI PROGRAMMAZIONE
LINGUAGGI DI PROGRAMMAZIONE Il potere espressivo di un linguaggio è caratterizzato da: quali tipi di dati consente di rappresentare (direttamente o tramite definizione dell utente) quali istruzioni di
Il File System. Il file system
Il File System Il file system Parte di SO che fornisce i meccanismi di accesso e memorizzazione delle informazioni (programmi e dati) allocate in memoria di massa Realizza i concetti astratti di file:
Processi in Linux. Igino Corona [email protected]. 20 Ottobre 2009
Sistemi Operativi Processi in Linux Igino Corona [email protected] 20 Ottobre 2009 Contenuti della lezione Come funzionano i programmi in Linux? Schema base di esecuzione di un programma Modalità
Sistema di protezione (1)
Sistema di protezione (1) - Un processo potrebbe tentare di modificare il programma o i dati di un altro processo o di parte del S.O. stesso. - Protezione: politiche (cosa) e meccanismi (come) per controllare
Sistema di protezione (2) Protezione (1)
Sistema di protezione (1) Sistema di protezione (2) Sistema di protezione (3) - Un processo potrebbe tentare di modificare il programma o i dati di un altro processo o di parte del S.O. stesso. - Protezione:
CREAZIONE PROCESSI IN UNIX 20
CREAZIONE PROCESSI IN UNIX 20 STRUTTURE DATI PER PROCESSI Un processo puo' essere in escuzione in 2 modi: kernel e utente. Un processo ha almeno 3 regioni: codice, dati e stack Lo stack è allocato dinamicamente.
Struttura del Micro Filesystem (µfs)
Struttura del Micro Filesystem (µfs) Il Micro Filesystem deve essere organizzato all'interno di un unico file regolare Linux (dev_ufs) ed può basato sul filesystem FAT-32 con la gestione dei permessi in
Sistemi Operativi: Programmazione di Sistema
Corso di Sistemi Operativi: Programmazione di Sistema Corso di Laurea in Informatica, Università di Firenze Anno accademico 2011/2012 Prof. Luca Ferrari e-mail: [email protected] telefono: 055 4237454
Funzioni in C. Violetta Lonati
Università degli studi di Milano Dipartimento di Scienze dell Informazione Laboratorio di algoritmi e strutture dati Corso di laurea in Informatica Funzioni - in breve: Funzioni Definizione di funzioni
Allocazione dinamica della memoria - riepilogo
Università degli studi di Milano Dipartimento di Scienze dell Informazione Laboratorio di algoritmi e strutture dati Corso di laurea in Informatica In breve Storage duration Allocazione dinamica della
Funzioni. Il modello console. Interfaccia in modalità console
Funzioni Interfaccia con il sistema operativo Argomenti sulla linea di comando Parametri argc e argv Valore di ritorno del programma La funzione exit Esercizio Calcolatrice 2, presente in tutti i programmi
Il SOFTWARE DI BASE (o SOFTWARE DI SISTEMA)
Il software Software Il software Il software è la sequenza di istruzioni che permettono ai computer di svolgere i loro compiti ed è quindi necessario per il funzionamento del calcolatore. Il software può
Il file system. meccanismi di accesso e memorizzazione delle informazioni (programmi e dati) allocate. in memoria di massa
Il File System 1 Il file system E quella componente del SO che fornisce i meccanismi di accesso e memorizzazione delle informazioni (programmi e dati) allocate in memoria di massa Realizza i concetti astratti
Capitolo Quarto...2 Le direttive di assemblaggio di ASM 68000...2 Premessa...2 1. Program Location Counter e direttiva ORG...2 2.
Capitolo Quarto...2 Le direttive di assemblaggio di ASM 68000...2 Premessa...2 1. Program Location Counter e direttiva ORG...2 2. Dichiarazione di dati: le direttive DS e DC...3 2.1 Direttiva DS...3 2.2
Posix Threads: l evoluzione dei processi UNIX
Posix Threads: l evoluzione dei processi UNIX Raffaele Quitadamo, PhD in Computer Science Università di Modena e Reggio Emilia [email protected] Sommario Pthreads vs Unix processes L API per
Le funzioni in C. I programmi C sono costituiti da definizioni di variabili e funzioni.
Le funzioni in C I programmi C sono costituiti da definizioni di variabili e funzioni. Una definizione di funzione ha il seguente formato: tipo-ritornato nome-funzione(lista-parametri) { dichiarazioni
Gli array. Gli array. Gli array. Classi di memorizzazione per array. Inizializzazione esplicita degli array. Array e puntatori
Gli array Array e puntatori Laboratorio di Informatica I un array è un insieme di elementi (valori) avente le seguenti caratteristiche: - un array è ordinato: agli elementi dell array è assegnato un ordine
Il memory manager. Gestione della memoria centrale
Il memory manager Gestione della memoria centrale La memoria La memoria RAM è un vettore molto grande di WORD cioè celle elementari a 16bit, 32bit, 64bit (2Byte, 4Byte, 8Byte) o altre misure a seconda
Inter-Process Communication
Inter-Process Communication (IPC) IPCS 1 1. Code di messaggi 2. Semafori 3. Memoria condivisa send receive 2? 3 p1 p3 p2 CODE DI MESSAGGI Modello di Comunicazione Code di Messaggi Il processo ricevente
Lab. di Sistemi Operativi - Esercitazione n 7- -Gestione dei processi Unix-
Lab. di Sistemi Operativi - Esercitazione n 7- -Gestione dei processi Unix- 1 Sommario Esercizi sulla gestione dei processi Creazione di un nuovo processo: fork Sincronizzazione tra processi: wait 2 -
Definizione Parte del software che gestisce I programmi applicativi L interfaccia tra il calcolatore e i programmi applicativi Le funzionalità di base
Sistema operativo Definizione Parte del software che gestisce I programmi applicativi L interfaccia tra il calcolatore e i programmi applicativi Le funzionalità di base Architettura a strati di un calcolatore
Lab. di Sistemi Operativi - Esercitazione n 9- -Thread-
Lab. di Sistemi Operativi - Esercitazione n 9- -Thread- 1 Sommario Esercizi su: Comunicazione tra processi: la funzione pipe() Condivisione dati e codice tra due o più processi: concetto di Thread 2 -
Makefile. Un target in generale e' un file. Usando.PHONY: target specifichiamo a make che il target non e' un file
Makefile Un target in generale e' un file. Usando.PHONY: target specifichiamo a make che il target non e' un file make target C./dir in pratica equivale all'esecuzione del comando make target all'interno
Dall Algoritmo al Programma. Prof. Francesco Accarino IIS Altiero Spinelli Sesto San Giovanni
Dall Algoritmo al Programma Prof. Francesco Accarino IIS Altiero Spinelli Sesto San Giovanni IL PROGRAMMA Gli algoritmi sono modelli di descrizione astratti e per controllarne il funzionamento devono essere
Dispensa 3. 1.1 YACC: generalità
Dispensa 3 1.1 YACC: generalità Il tool Yacc (acronimo per Yet Another Compiler Compiler) è uno strumento software che a partire da una specifica grammaticale context free di un linguaggio scritta in un
GESTIONE DEI PROCESSI
Sistemi Operativi GESTIONE DEI PROCESSI Processi Concetto di Processo Scheduling di Processi Operazioni su Processi Processi Cooperanti Concetto di Thread Modelli Multithread I thread in Java Concetto
Esercitazione [5] Input/Output su Socket
Esercitazione [5] Input/Output su Socket Leonardo Aniello - [email protected] Daniele Cono D'Elia - [email protected] Sistemi di Calcolo - Secondo modulo (SC2) Programmazione dei Sistemi di Calcolo
Con il termine Sistema operativo si fa riferimento all insieme dei moduli software di un sistema di elaborazione dati dedicati alla sua gestione.
Con il termine Sistema operativo si fa riferimento all insieme dei moduli software di un sistema di elaborazione dati dedicati alla sua gestione. Compito fondamentale di un S.O. è infatti la gestione dell
Inter Process Communication. Laboratorio Software 2008-2009 C. Brandolese
Inter Process Communication Laboratorio Software 2008-2009 C. Brandolese Introduzione Più processi o thread Concorrono alla relaizzazione di una funzione applicativa Devono poter realizzare Sincronizzazione
Gestione dei File in C
Gestione dei File in C Maurizio Palesi DIIT Università di Catania Viale Andrea Doria 6, 95125 Catania [email protected] http://www.diit.unict.it/users/mpalesi Sommario In questo documento saranno introdotte
Il Sistema Operativo
Il Sistema Operativo Il Sistema Operativo Il Sistema Operativo (S.O.) è un insieme di programmi interagenti che consente agli utenti e ai programmi applicativi di utilizzare al meglio le risorse del Sistema
Variabili e tipi di dato
Variabili e tipi di dato Tutte le variabili devono essere dichiarate, specificandone il tipo La dichiarazione deve precedere l uso Il tipo è un concetto astratto che esprime: L allocazione di spazio per
API e socket per lo sviluppo di applicazioni Web Based
API e socket per lo sviluppo di applicazioni Web Based Cosa sono le API? Consideriamo il problema di un programmatore che voglia sviluppare un applicativo che faccia uso dei servizi messi a disposizione
Hardware di un Computer
Hardware di un Computer Monitor Mouse Tastiera Printer Disk CPU Graphics Adapter USB Controller Parallel Port Disk Controller BUS Memoria RAM Memoria ROM (BIOS) DMA CPU esegue istruzioni, effettua calcoli,
NOZIONI BASE PER ESERCITAZIONI
NOZIONI BASE PER ESERCITAZIONI Shahram Rahatlou Laboratorio di Calcolo, Anno Accademico 2015-16 http://www.roma1.infn.it/people/rahatlou/labcalc/ Sistema Operativo Hardware Software n Routine e programmi
Sistemi Operativi Il Sistema Operativo Windows (parte 3)
Sistemi Operativi Il Sistema Operativo Windows (parte 3) Docente: Claudio E. Palazzi [email protected] Crediti per queste slides al Prof. Tullio Vardanega Architettura di NTFS 1 NTFS file system adottato
Compilatore risorse display grafico LCD serie IEC-line
Compilatore risorse display grafico LCD serie IEC-line aggiornamento: 22-11-2012 IEC-line by OVERDIGIT overdigit.com 1. Il display grafico LCD I PLC della serie IPC-line possono disporre opzionalmente
STRUTTURE DEI SISTEMI DI CALCOLO
STRUTTURE DEI SISTEMI DI CALCOLO 2.1 Strutture dei sistemi di calcolo Funzionamento Struttura dell I/O Struttura della memoria Gerarchia delle memorie Protezione Hardware Architettura di un generico sistema
Software di sistema e software applicativo. I programmi che fanno funzionare il computer e quelli che gli permettono di svolgere attività specifiche
Software di sistema e software applicativo I programmi che fanno funzionare il computer e quelli che gli permettono di svolgere attività specifiche Software soft ware soffice componente è la parte logica
Sistemi Operativi (modulo di Informatica II) I processi
Sistemi Operativi (modulo di Informatica II) I processi Patrizia Scandurra Università degli Studi di Bergamo a.a. 2009-10 Sommario Il concetto di processo Schedulazione dei processi e cambio di contesto
Algoritmi di scheduling
Capitolo 3 Algoritmi di scheduling Come caso particolare di studio, di seguito è discussa in dettaglio la politica di scheduling del sistema operativo LINUX (kernel precedente alla versione 2.6). Sono
Laboratorio di Ingegneria del software Sistema di controllo di un ascensore Requisisti preliminari
Laboratorio di Ingegneria del software Sistema di controllo di un ascensore Requisisti preliminari A.A. 2012 2013 1 Introduzione Questo documento raccoglie i requisiti preliminari per il software di controllo
Gian Luca Marcialis studio degli algoritmi programma linguaggi LINGUAGGIO C
Università degli Studi di Cagliari Corso di Laurea in Ingegneria Biomedica (Industriale), Chimica, Elettrica, e Meccanica FONDAMENTI DI INFORMATICA 1 http://www.diee.unica.it/~marcialis/fi1 A.A. 2010/2011
Introduzione al Linguaggio C
Introduzione al Linguaggio C File I/O Daniele Pighin April 2009 Daniele Pighin Introduzione al Linguaggio C 1/15 Outline File e dati Accesso ai file File I/O Daniele Pighin Introduzione al Linguaggio C
Inizializzazione, Assegnamento e Distruzione di Classi
Inizializzazione, Assegnamento e Distruzione di Classi Lezione 9 Operazioni Automatiche In ogni programma C++ oggetti classe vengono gestiti automaticamente dal compilatore Inizializzati al momento della
Lezione 1: L architettura LC-3 Laboratorio di Elementi di Architettura e Sistemi Operativi 10 Marzo 2014
Lezione 1: L architettura LC-3 Laboratorio di Elementi di Architettura e Sistemi Operativi 10 Marzo 2014 Ricorda... Il ciclo di esecuzione di un istruzione è composto da sei fasi: FETCH DECODE ADDRESS
----------------------------------------------------------------
---------------------------------------------------------------- utilizzo frequente di chiamate a.. A differenza del Pascal, il C permette di operare con assegnamenti e confronti su dati di tipo diverso,
Programmazione C Massimo Callisto De Donato [email protected] www.cs.unicam.it/massimo.callisto
Università degli studi di Camerino Scuola di scienze e tecnologia - Sezione Informatica Programmazione C Massimo Callisto De Donato [email protected] www.cs.unicam.it/massimo.callisto LEZIONE
