Corretta la bibliografia
[gapil.git] / fileintro.tex
1 \chapter{L'architettura dei file}
2 \label{cha:file_intro}
3
4 Uno dei concetti fondamentali dell'architettura di un sistema Unix è il
5 cosiddetto \textit{everything is a file}, cioè il fatto che l'accesso ai vari
6 dispositivi di input/output del computer viene effettuato attraverso
7 un'interfaccia astratta che tratta le periferiche allo stesso modo dei normali
8 file di dati.
9
10 Questo significa che si può accedere a qualunque periferica del computer,
11 dalla seriale, alla parallela, alla console, e agli stessi dischi attraverso i
12 cosiddetti file di dispositivo (i \textit{device file}). Questi sono dei file
13 speciali agendo sui quali i programmi possono leggere, scrivere e compiere
14 operazioni direttamente sulle periferiche, usando le stesse funzioni che si
15 usano per i normali file di dati.
16
17 In questo capitolo forniremo una descrizione dell'architettura dei file in
18 Linux, iniziando da una panoramica sulle caratteristiche principali delle
19 interfacce con cui i processi accedono ai file (che tratteremo in dettaglio
20 nei capitoli seguenti), per poi passare ad una descrizione più dettagliata
21 delle modalità con cui detto accesso viene realizzato dal sistema.
22
23
24
25 \section{L'architettura generale}
26 \label{sec:file_access_arch}
27
28 Per poter accedere ai file il kernel deve mettere a disposizione dei programmi
29 le opportune interfacce che consentano di leggerne il contenuto; il sistema
30 cioè deve provvedere ad organizzare e rendere accessibile in maniera opportuna
31 l'informazione tenuta sullo spazio grezzo disponibile sui dischi. Questo viene
32 fatto strutturando l'informazione sul disco attraverso quello che si chiama un
33 \textit{filesystem} (vedi \ref{sec:file_arch_func}), essa poi viene resa
34 disponibile ai processi attraverso quello che viene chiamato il
35 \textsl{montaggio} del \textit{filesystem}.
36 % (approfondiremo tutto ciò in \secref{sec:file_arch_func}).
37
38 In questa sezione faremo una panormamica generica su come il sistema presenta
39 i file ai processi, trattando l'organizzazione di file e directory, i tipi di
40 file ed introducendo le interfacce disponibili e le loro caratteristiche.
41
42
43 \subsection{L'organizzazione di file e directory}
44 \label{sec:file_organization}
45
46 In Unix, a differenza di quanto avviene in altri sistemi operativi, tutti i
47 file vengono tenuti all'interno di un unico albero la cui radice (quella che
48 viene chiamata \textit{root directory}) viene montata all'avvio.  Un file
49 viene identificato dall'utente usando quello che viene chiamato
50 \textit{pathname}\footnote{anche se il manuale della \acr{glibc} depreca
51   questa nomenclatura, poiché genererebbe confusione, dato che con
52   \textit{path} si indica anche un insieme di directory su cui effettuare una
53   ricerca (come quello in cui si cercano i comandi) non seguiremo questa
54   scelta dato che l'uso della parola \textit{pathname} è ormai così comune che
55   mantenerne l'uso è senz'altro più chiaro dell'alternativa proposta.}, cioè
56 il percorso che si deve fare per accedere al file a partire dalla \textit{root
57   directory}, che è composto da una serie di nomi separati da una \file{/}.
58
59 All'avvio del sistema, comletata la fase di inizializzazione il kernel riceve
60 dal boot loader l'indicazione di quale dispositivo contiene il filesystem da
61 usare come punto di partenza e questo viene montato come radice dell'albero
62 (cioè nella directory \file{/}); tutti gli ulteriori filesystem che possono
63 essere su altri dispositivi dovranno poi essere inseriti nell'albero
64 montandoli su opportune directory del filesystem montato come radice.
65
66 Alcuni filesystem speciali (come \file{/proc} che contiene un'interfaccia ad
67 alcune strutture interne del kernel) sono generati automaticamente dal kernel
68 stesso, ma anche essi devono essere montati all'interno dell'albero dei file.
69
70 Una directory, come vedremo in maggior dettaglio in
71 \secref{sec:file_vfs_work}, è anch'essa un file, solo che è un file
72 particolare che il kernel riconosce come tale. Il suo scopo è quello di
73 contenere una lista di nomi di file e le informazioni che associano ciascun
74 nome al contenuto. Dato che questi nomi possono corrispondere ad un qualunque
75 oggetto del filesystem, compresa un'altra directory, si ottiene naturalmente
76 un'organizzazione ad albero inserendo directory in altre directory.
77
78 Un file può essere indicato rispetto alla directory corrente semplicemente
79 specificandone il nome\footnote{Il manuale delle \acr{glibc} chiama i nomi
80   contenuti nelle directory \textsl{componenti} (in inglese \textit{file name
81     components}), noi li chiameremo più semplicemente \textit{nomi}.} da essa
82 contenuto.  All'interno dello stesso albero si potranno poi inserire anche
83 tutti gli altri oggetti visti attraverso l'interfaccia che manipola i file
84 come le fifo, i link, i socket e gli stessi i file di dispositivo (questi
85 ultimi, per convenzione, sono inseriti nella directory \file{/dev}).
86
87 Il nome completo di un file viene chiamato \textit{pathname} ed il
88 procedimento con cui si individua il file a cui esso fa riferimento è chiamato
89 risoluzione del nome (\textit{file name resolution} o \textit{pathname
90   resolution}).  La risoluzione viene fatta esaminando il \textit{pathname} da
91 sinistra a destra e localizzando ogni nome nella directory indicata dal nome
92 precedente usando \file{/} come separatore\footnote{nel caso di nome vuoto, il
93   costrutto \file{//} viene considerato equivalente a \file{/}.}: ovviamente,
94 perché il procedimento funzioni, occorre che i nomi indicati come directory
95 esistano e siano effettivamente directory, inoltre i permessi (si veda
96 \secref{sec:file_access_control}) devono consentire l'accesso all'intero
97 \textit{pathname}.
98
99 Se il \textit{pathname} comincia per \file{/} la ricerca parte dalla directory
100 radice del processo; questa, a meno di un \func{chroot} (su cui torneremo in
101 \secref{sec:file_chroot}) è la stessa per tutti i processi ed equivale alla
102 directory radice dell'albero dei file: in questo caso si parla di un
103 \textsl{pathname assoluto}\index{pathname assoluto}. Altrimenti la ricerca
104 parte dalla directory corrente (su cui torneremo in
105 \secref{sec:file_work_dir}) ed il pathname è detto \textsl{pathname
106   relativo}\index{pathname relativo}.
107
108 I nomi \file{.} e \file{..} hanno un significato speciale e vengono inseriti
109 in ogni directory: il primo fa riferimento alla directory corrente e il
110 secondo alla directory \textsl{genitrice} (o \textit{parent directory}) cioè
111 la directory che contiene il riferimento alla directory corrente; nel caso
112 questa sia la directory radice, allora il riferimento è a se stessa.
113
114
115 \subsection{I tipi di file}
116 \label{sec:file_file_types}
117
118 Come detto in precedenza in Unix esistono vari tipi di file; in Linux questi
119 sono implementati come oggetti del \textit{Virtual File System} (vedi
120 \secref{sec:file_vfs_work}) e sono presenti in tutti i filesystem unix-like
121 utilizzabili con Linux. L'elenco dei vari tipi di file definiti dal
122 \textit{Virtual File System}\index{Virtual File System} è riportato in \ntab.
123
124 Si tenga ben presente che questa classificazione non ha nulla a che fare con
125 la classificazione sui tipi di file (che in questo caso sono sempre file di
126 dati) in base al loro contenuto, o tipo di accesso.
127
128 \begin{table}[htb]
129   \footnotesize
130   \centering
131     \begin{tabular}[c]{|l|l|p{7cm}|}
132     \hline
133     \multicolumn{2}{|c|}{\textbf{Tipo di file}} & \textbf{Descrizione} \\
134     \hline
135     \hline
136       \textit{regular file} & \textsl{file normale} &
137       un file che contiene dei dati (l'accezione normale di file) \\
138       \textit{directory} & \textsl{cartella o direttorio} &
139       un file che contiene una lista di nomi associati a degli \textit{inodes}
140       (vedi \secref{sec:file_vfs}).  \\
141       \textit{symbolic link} & \textsl{collegamento simbolico} &
142       un file che contiene un riferimento ad un altro file/directory \\
143       \textit{char device} & \textsl{dispositivo a caratteri} &
144       un file che identifica una periferica ad accesso sequenziale \\
145       \textit{block device} & \textsl{dispositivo a blocchi} &
146       un file che identifica una periferica ad accesso diretto \\
147       \textit{fifo} & \textsl{``coda''} &
148       un file speciale che identifica una linea di comunicazione software
149       (unidirezionale) \\
150       \textit{socket} & \textsl{``presa''} &
151       un file speciale che identifica una linea di comunicazione software
152       (bidirezionale) \\
153     \hline
154     \end{tabular}
155     \caption{Tipologia dei file definiti nel VFS}
156     \label{tab:file_file_types}
157 \end{table}
158
159 Infatti una delle differenze principali con altri sistemi operativi (come il
160 VMS o Windows) è che per Unix tutti i file di dati sono identici e contengono
161 un flusso continuo di byte. Non esiste cioè differenza per come vengono visti
162 dal sistema file di diverso contenuto o formato (come nel caso di quella fra
163 file di testo e binari che c'è in Windows) né c'è una strutturazione a record
164 per il cosiddetto ``accesso diretto'' come nel caso del VMS.\footnote{con i
165   kernel della serie 2.4 è disponibile una forma di accesso diretto ai dischi
166   (il \textit{raw access}) attraverso dei device file appositi, che però non
167   ha nulla a che fare con questo.}
168
169 Una seconda differenza è nel formato dei file ASCII; in Unix la fine riga è
170 codificata in maniera diversa da Windows o Mac, in particolare il fine riga è
171 il carattere \texttt{LF} (o \verb|\n|) al posto del \texttt{CR} (\verb|\r|)
172 del Mac e del \texttt{CR LF} di Windows.\footnote{per questo esistono in Linux
173   dei programmi come \cmd{unix2dos} e \cmd{dos2unix} che effettuano una
174   conversione fra questi due formati di testo.} Questo può causare alcuni
175 problemi qualora nei programmi si facciano assunzioni sul terminatore della
176 riga.
177
178 Si ricordi infine che in ambiente Unix non esistono tipizzazioni dei file di
179 dati e che non c'è nessun supporto del sistema per le estensioni come parte
180 del filesystem. Ciò nonostante molti programmi adottano delle convenzioni per
181 i nomi dei file, ad esempio il codice C normalmente si mette in file con
182 l'estensione \file{.c}, ma questa è, per quanto usata ed accettata in maniera
183 universale, solo una convenzione.
184
185
186 \subsection{Le due interfacce ai file}
187 \label{sec:file_io_api}
188
189 In Linux le modalità di accesso ai file e le relative interfacce di
190 programmazione sono due, basate su due diversi meccanismi con cui è possibile
191 accedere al loro contenuto.
192
193 La prima è l'interfaccia standard di Unix, quella che il manuale delle
194 \acr{glibc} chiama interfaccia dei descrittori di file (o \textit{file
195   descriptor}).  È un'interfaccia specifica dei sistemi unix-like e provvede
196 un accesso non bufferizzato; la tratteremo in dettaglio in
197 \capref{cha:file_unix_interface}.
198
199 L'interfaccia è primitiva ed essenziale, l'accesso viene detto non
200 bufferizzato in quanto la lettura e la scrittura vengono eseguite chiamando
201 direttamente le system call del kernel (in realtà il kernel effettua al suo
202 interno alcune bufferizzazioni per aumentare l'efficienza nell'accesso ai
203 dispositivi); i \textit{file descriptor}\index{file descriptor} sono
204 rappresentati da numeri interi (cioè semplici variabili di tipo \type{int}).
205 L'interfaccia è definita nell'header \file{unistd.h}.
206
207 La seconda interfaccia è quella che il manuale della \acr{glibc} chiama degli
208 \textit{stream}\index{stream}. Essa provvede funzioni più evolute e un accesso
209 bufferizzato (controllato dalla implementazione fatta dalle \acr{glibc}), la
210 tratteremo in dettaglio nel \capref{cha:files_std_interface}.
211
212 Questa è l'interfaccia standard specificata dall'ANSI C e perciò si trova
213 anche su tutti i sistemi non Unix. Gli \textit{stream} sono oggetti complessi
214 e sono rappresentati da puntatori ad un opportuna struttura definita dalle
215 librerie del C; si accede ad essi sempre in maniera indiretta utilizzando il
216 tipo \type{FILE *}.  L'interfaccia è definita nell'header \type{stdio.h}.
217
218 Entrambe le interfacce possono essere usate per l'accesso ai file come agli
219 altri oggetti del VFS (pipe, socket, device, sui quali torneremo in dettaglio
220 a tempo opportuno), ma per poter accedere alle operazioni di controllo su un
221 qualunque tipo di oggetto del VFS occorre usare l'interfaccia standard di Unix
222 con i \textit{file descriptor}. Allo stesso modo devono essere usati i
223 \textit{file descriptor} se si vuole ricorrere a modalità speciali di I/O come
224 il polling o il non-bloccante (vedi \capref{cha:file_advanced}).
225
226 Gli \textit{stream} forniscono un'interfaccia di alto livello costruita sopra
227 quella dei \textit{file descriptor}, che permette di poter scegliere tra
228 diversi stili di bufferizzazione.  Il maggior vantaggio degli \textit{stream}
229 è che l'interfaccia per le operazioni di input/output è enormemente più ricca
230 di quella dei \textit{file descriptor}, che provvedono solo funzioni
231 elementari per la lettura/scrittura diretta di blocchi di byte.  In
232 particolare gli \textit{stream} dispongono di tutte le funzioni di
233 formattazione per l'input e l'output adatte per manipolare anche i dati in
234 forma di linee o singoli caratteri.
235
236 In ogni caso, dato che gli stream sono implementati sopra l'interfaccia
237 standard di Unix, è sempre possibile estrarre il \textit{file descriptor} da
238 uno stream ed eseguirvi operazioni di basso livello, o associare in un secondo
239 tempo uno \textit{stream} ad un \textit{file descriptor}.
240
241 In generale, se non necessitano specificatamente le funzionalità di basso
242 livello, è opportuno usare sempre gli \textit{stream} per la loro maggiore
243 portabilità, essendo questi ultimi definiti nello standard ANSI C;
244 l'interfaccia con i \textit{file descriptor} infatti segue solo lo standard
245 POSIX.1 dei sistemi Unix, ed è pertanto di portabilità più limitata.
246
247
248 % \subsection{Caratteristiche specifiche dei file in Unix}
249 % \label{sec:fileint_unix_spec}
250
251 % Essendo un sistema multitasking e multiutente esistono alcune caratteristiche
252 % specifiche di un sistema unix-like che devono essere tenute in conto
253 % nell'accesso ai file. È infatti normale che più processi o programmi possano
254 % accedere contemporaneamente allo stesso file e devono poter eseguire le loro
255 % operazioni indipendentemente da quello che fanno gli altri processi.
256
257 % Per questo motivo le strutture usate per all'accesso ai file sono relative al
258 % processo che effettua l'accesso.  All'apertura di ogni file infatti viene
259 % creata all'interno del processo una apposita struttura in cui sono memorizzati
260 % tutti gli attributi del medesimo, che viene utilizzata per tutte le
261 % operazioni. Questa è una struttura che resta locale al processo stesso; in
262 % questo modo processi diversi possono usare le proprie strutture locali per
263 % accedere ai file (che può essere sempre lo stesso) in maniera assolutamente
264 % indipendente.
265
266 % Questo ha delle conseguenze di cui è bene tenere conto; ad esempio in tutti i
267 % sistemi POSIX uno degli attributi di un file aperto è la posizione corrente nel
268 % file, cioè il punto nel file in cui verrebbe letto o scritto alla operazione
269 % successiva. Essa è rappresentata da un numero intero che indica il numero di
270 % byte dall'inizio del file, che viene (a meno che non si apra il file in
271 % append) inizializzato a zero all'apertura del medesimo.
272
273 % Questo è uno dei dati che viene mantenuto nella suddetta struttura, per cui
274 % ogni processo avrà la sua posizione corrente nel file, che non sarà
275 % influenzata da quello che altri processi possono fare. Anzi, aprire un file
276 % significa appunto creare ed inizializzare una tale struttura, per cui se si
277 % apre due volte lo stesso file all'interno dello stesso processo, si otterranno
278 % due file descriptor o due stream che avranno ancora una posizione corrente nel
279 % file assolutamente indipendente.
280
281 % Si tenga conto inoltre che un'altro dei dati contenuti nella struttura di
282 % accesso è un riferimento all'inode del file, pertanto anche se il file viene
283 % cancellato da un altro processo, sarà sempre possibile mantenere l'accesso ai
284 % dati, e lo spazio su disco non verrà rilasciato fintanto che il file non sarà
285 % chiuso e l'ultimo riferimento cancellato. È pertanto possibile (come vedremo
286 % in dettaglio in \secref{sec:file_link}) aprire un file provvisorio per
287 % cancellarlo immediatamente dopo; in questo modo all'uscita del programma il
288 % file scomparirà definitivamente dal disco, ma il file ed il suo contenuto
289 % saranno disponibili per tutto il tempo in cui il processo è attivo.
290
291 % Ritorneremo su questo più avanti in \secref{sec:file_fd}, quando tratteremo
292 % l'input/output sui file, esaminando in dettaglio come tutto ciò viene
293 % realizzato.
294
295
296 \section{L'architettura della gestione dei file}
297 \label{sec:file_arch_func}
298
299 Per capire fino in fondo le proprietà di file e directory in un sistema
300 unix-like ed il comportamento delle relative funzioni di manipolazione occorre
301 una breve introduzione al funzionamento gestione dei file da parte del kernel
302 e sugli oggetti su cui è basato un filesystem. In particolare occorre tenere
303 presente dov'è che si situa la divisione fondamentale fra kernel space e user
304 space che tracciavamo al \capref{cha:intro_unix}.
305
306 In questa sezione esamineremo come viene implementato l'accesso ai file in
307 Linux, come il kernel può gestire diversi tipi di filesystem, descrivendo
308 prima le caratteristiche generali di un filesystem di un sistema unix-like,
309 per poi trattare in maniera un po' più dettagliata il filesystem standard di
310 Linux, l'\acr{ext2}.
311
312 % in particolare si riprenderà, approfondendolo sul piano dell'uso nelle
313 % funzioni di libreria, il concetto di \textit{inode} di cui abbiamo brevemente
314 % accennato le caratteristiche (dal lato dell'implementazione nel kernel) in
315 % \secref{sec:file_vfs}.
316
317
318 \subsection{Il \textit{Virtual Filesystem} di Linux}
319 \label{sec:file_vfs}
320
321 % Questa sezione riporta informazioni sui dettagli di come il kernel gestisce i
322 % file.  L'argomento è abbastanza ``esoterico'' e questa sezione può essere
323 % saltata ad una prima lettura; è bene però tenere presente che vengono
324 % introdotti qui alcuni termini che potranno comparire in seguito, come
325 % \textit{inode}, \textit{dentry}, \textit{dcache}.
326
327 In Linux il concetto di \textit{everything is a file} è stato implementato
328 attraverso il \textit{Virtual Filesystem} (da qui in avanti VFS) che è uno
329 strato intermedio che il kernel usa per accedere ai più svariati filesystem
330 mantenendo la stessa interfaccia per i programmi in user space. Esso provvede
331 un livello di indirezione che permette di collegare le operazioni di
332 manipolazione sui file alle operazioni di I/O, e gestisce l'organizzazione di
333 queste ultime nei vari modi in cui diversi filesystem le effettuano,
334 permettendo la coesistenza di filesystem differenti all'interno dello stesso
335 albero delle directory.
336
337 Quando un processo esegue una system call che opera su un file il kernel
338 chiama sempre una funzione implementata nel VFS; la funzione eseguirà le
339 manipolazioni sulle strutture generiche e utilizzerà poi la chiamata alla
340 opportune routine del filesystem specifico a cui si fa riferimento. Saranno
341 queste a chiamare le funzioni di più basso livello che eseguono le operazioni
342 di I/O sul dispositivo fisico, secondo lo schema riportato in \nfig.
343
344 \begin{figure}[htb]
345   \centering
346   \includegraphics[width=7cm]{img/vfs}
347   \caption{Schema delle operazioni del VFS}
348   \label{fig:file_VFS_scheme}
349 \end{figure}
350
351 Il VFS definisce un insieme di funzioni che tutti i filesystem devono
352 implementare. L'interfaccia comprende tutte le funzioni che riguardano i file;
353 le operazioni sono suddivise su tre tipi di oggetti: \textit{filesystem},
354 \textit{inode} e \textit{file}, corrispondenti a tre apposite strutture
355 definite nel kernel.
356
357 Il VFS usa una tabella mantenuta dal kernel che contiene il nome di ciascun
358 filesystem supportato: quando si vuole inserire il supporto di un nuovo
359 filesystem tutto quello che occorre è chiamare la funzione
360 \code{register\_filesystem} passandole un'apposita struttura
361 (\var{file\_system\_type}) che contiene i dettagli per il riferimento
362 all'implementazione del medesimo, che sarà aggiunta alla citata tabella.
363
364 In questo modo quando viene effettuata la richiesta di montare un nuovo disco
365 (o qualunque altro \textit{block device} che può contenere un filesystem), il
366 VFS può ricavare dalla citata tabella il puntatore alle funzioni da chiamare
367 nelle operazioni di montaggio. Quest'ultima è responsabile di leggere da disco
368 il superblock (vedi \secref{sec:file_ext2}), inizializzare tutte le variabili
369 interne e restituire uno speciale descrittore dei filesystem montati al VFS;
370 attraverso quest'ultimo diventa possibile accedere alle routine specifiche per
371 l'uso di quel filesystem.
372
373 Il primo oggetto usato dal VFS è il descrittore di filesystem, un puntatore ad
374 una apposita struttura che contiene vari dati come le informazioni comuni ad
375 ogni filesystem, i dati privati relativi a quel filesystem specifico, e i
376 puntatori alle funzioni del kernel relative al filesystem. Il VFS può così
377 usare le funzioni contenute nel \textit{filesystem descriptor} per accedere
378 alle routine specifiche di quel filesystem.
379
380 Gli altri due descrittori usati dal VFS sono relativi agli altri due oggetti
381 su cui è strutturata l'interfaccia. Ciascuno di essi contiene le informazioni
382 relative al file in uso, insieme ai puntatori alle funzioni dello specifico
383 filesystem usate per l'accesso dal VFS; in particolare il descrittore
384 dell'inode contiene i puntatori alle funzioni che possono essere usate su
385 qualunque file (come \func{link}, \func{stat} e \func{open}), mentre il
386 descrittore di file contiene i puntatori alle funzioni che vengono usate sui
387 file già aperti.
388
389
390 \subsection{Il funzionamento del VFS}
391 \label{sec:file_vfs_work}
392
393 La funzione più importante implementata dal VFS è la system call \func{open}
394 che permette di aprire un file. Dato un pathname viene eseguita una ricerca
395 dentro la \textit{directory entry cache} (in breve \textit{dcache}), una
396 tabella che contiene tutte le \textit{directory entry} (in breve
397 \textit{dentry}) che permette di associare in maniera rapida ed efficiente il
398 pathname a una specifica \textit{dentry}.
399
400 Una singola \textit{dentry} contiene in genere il puntatore ad un
401 \textit{inode}; quest'ultimo è la struttura base che sta sul disco e che
402 identifica un singolo oggetto del VFS sia esso un file ordinario, una
403 directory, un link simbolico, una FIFO, un file di dispositivo, o una
404 qualsiasi altra cosa che possa essere rappresentata dal VFS (i tipi di
405 ``file'' riportati in \tabref{tab:file_file_types}). A ciascuno di essi è
406 associata pure una struttura che sta in memoria, e che, oltre alle
407 informazioni sullo specifico file, contiene anche il riferimento alle funzioni
408 (i \textsl{metodi} del VFS) da usare per poterlo manipolare.
409
410 Le \textit{dentry} ``vivono'' in memoria e non vengono mai salvate su disco,
411 vengono usate per motivi di velocità, gli \textit{inode} invece stanno su
412 disco e vengono copiati in memoria quando serve, ed ogni cambiamento viene
413 copiato all'indietro sul disco, gli inode che stanno in memoria sono inode del
414 VFS ed è ad essi che puntano le singole \textit{dentry}.
415
416 La \textit{dcache} costituisce perciò una sorta di vista completa di tutto
417 l'albero dei file, ovviamente per non riempire tutta la memoria questa vista è
418 parziale (la \textit{dcache} cioè contiene solo le \textit{dentry} per i file
419 per i quali è stato richiesto l'accesso), quando si vuole risolvere un nuovo
420 pathname il VFS deve creare una nuova \textit{dentry} e caricare l'inode
421 corrispondente in memoria.
422
423 Questo procedimento viene eseguito dal metodo \code{lookup()} dell'inode
424 della directory che contiene il file; questo viene installato nelle relative
425 strutture in memoria quando si effettua il montaggio lo specifico filesystem
426 su cui l'inode va a vivere.
427
428 Una volta che il VFS ha a disposizione la \textit{dentry} (ed il relativo
429 \textit{inode}) diventa possibile accedere alle varie operazioni sul file come
430 la \func{open} per aprire il file o la \func{stat} per leggere i dati
431 dell'inode e passarli in user space.
432
433 L'apertura di un file richiede comunque un'altra operazione, l'allocazione di
434 una struttura di tipo \var{file} in cui viene inserito un puntatore alla
435 \textit{dentry} e una struttura \var{f\_ops} che contiene i puntatori ai
436 metodi che implementano le operazioni disponibili sul file. In questo modo i
437 processi in user space possono accedere alle operazioni attraverso detti
438 metodi, che saranno diversi a seconda del tipo di file (o dispositivo) aperto
439 (su questo torneremo in dettaglio in \secref{sec:file_fd}). Un elenco delle
440 operazioni previste dal kernel è riportato in \ntab.
441
442 \begin{table}[htb]
443   \centering
444   \footnotesize
445   \begin{tabular}[c]{|l|p{7cm}|}
446     \hline
447     \textbf{Funzione} & \textbf{Operazione} \\
448     \hline
449     \hline
450     \textsl{\code{open}}   & apre il file \\
451     \textsl{\code{read}}   & legge dal file \\
452     \textsl{\code{write}}  & scrive sul file \\ 
453     \textsl{\code{llseek}} & sposta la posizione corrente sul file \\
454     \textsl{\code{ioctl}}  & accede alle operazioni di controllo 
455                        (tramite la \func{ioctl})\\
456     \textsl{\code{readdir}}& per leggere il contenuto di una directory \\
457     \textsl{\code{poll}}   & \\
458     \textsl{\code{mmap}}   & chiamata dalla system call \func{mmap}. 
459                        mappa il file in memoria\\
460     \textsl{\code{release}}& chiamata quando l'ultima referenza a un file 
461                        aperto è chiusa\\
462     \textsl{\code{fsync}}  & chiamata dalla system call \func{fsync} \\
463     \textsl{\code{fasync}} & chiamate da \func{fcntl} quando è abilitato 
464                            il modo asincrono per l'I/O su file. \\
465     \hline
466   \end{tabular}
467   \caption{Operazioni sui file definite nel VFS.}
468   \label{tab:file_file_operations}
469 \end{table}
470
471 In questo modo per ciascun file diventano possibili una serie di operazioni
472 (non è detto che tutte siano disponibili), che costituiscono l'interfaccia
473 astratta del VFS.  Qualora se ne voglia eseguire una il kernel andrà ad
474 utilizzare la opportuna routine dichiarata in \var{f\_ops} appropriata al tipo
475 di file in questione.
476
477 In questo modo è possibile scrivere allo stesso modo sulla porta seriale come
478 su un file di dati normale; ovviamente certe operazioni (nel caso della
479 seriale ad esempio la \code{seek}) non saranno disponibili, però con questo
480 sistema l'utilizzo di diversi filesystem (come quelli usati da Windows o
481 MacOs) è immediato e (relativamente) trasparente per l'utente ed il
482 programmatore.
483
484
485 \subsection{Il funzionamento di un filesystem Unix}
486 \label{sec:file_filesystem}
487
488 Come già accennato in \secref{sec:file_organization} Linux (ed ogni sistema
489 unix-like) organizza i dati che tiene su disco attraverso l'uso di un
490 filesystem. Una delle caratteristiche di Linux rispetto agli altri Unix è
491 quella di poter supportare grazie al VFS una enorme quantità di filesystem
492 diversi, ognuno dei quali ha una sua particolare struttura e funzionalità
493 proprie.  Per questo per il momento non entreremo nei dettagli di un
494 filesystem specifico, ma daremo una descrizione a grandi linee che si adatta
495 alle caratteristiche comuni di qualunque filesystem di sistema unix-like.
496
497 Lo spazio fisico di un disco viene usualmente diviso in partizioni; ogni
498 partizione può contenere un filesystem. La strutturazione tipica
499 dell'informazione su un disco è riportata in \nfig; in essa si fa riferimento
500 alla struttura del filesystem \acr{ext2}, che prevede una separazione dei dati
501 in \textit{blocks group} che replicano il superblock (ma sulle caratteristiche
502 di \acr{ext2} torneremo in \secref{sec:file_ext2}). È comunque caratteristica
503 comune di tutti i filesystem per Unix, indipendentemente da come poi viene
504 strutturata nei dettagli questa informazione, prevedere una divisione fra la
505 lista degli inodes e lo spazio a disposizione per i dati e le directory.
506
507 \begin{figure}[htb]
508   \centering
509   \includegraphics[width=12cm]{img/disk_struct}
510   \caption{Organizzazione dello spazio su un disco in partizioni e filesystem}
511   \label{fig:file_disk_filesys}
512 \end{figure}
513
514 Se si va ad esaminare con maggiore dettaglio la strutturazione
515 dell'informazione all'interno del singolo filesystem (tralasciando i dettagli
516 relativi al funzionamento del filesystem stesso come la strutturazione in
517 gruppi dei blocchi, il superblock e tutti i dati di gestione) possiamo
518 esemplificare la situazione con uno schema come quello esposto in \nfig.
519
520 \begin{figure}[htb]
521   \centering
522   \includegraphics[width=12cm]{img/filesys_struct}
523   \caption{Strutturazione dei dati all'interno di un filesystem}
524   \label{fig:file_filesys_detail}
525 \end{figure}
526
527 Da \curfig\ si evidenziano alcune delle caratteristiche di base di un
528 filesystem, sulle quali è bene porre attenzione visto che sono fondamentali
529 per capire il funzionamento delle funzioni che manipolano i file e le
530 directory che tratteremo nel prossimo capitolo; in particolare è opportuno
531 ricordare sempre che:
532
533 \begin{enumerate}
534   
535 \item L'\textit{inode} contiene tutte le informazioni riguardanti il file: il
536   tipo di file, i permessi di accesso, le dimensioni, i puntatori ai blocchi
537   fisici che contengono i dati e così via; le informazioni che la funzione
538   \func{stat} fornisce provengono dall'\textit{inode}; dentro una directory si
539   troverà solo il nome del file e il numero dell'\textit{inode} ad esso
540   associato, cioè quella che da qui in poi chiameremo una \textsl{voce}
541   (traduzione approssimata dell'inglese \textit{directory entry}, che non
542   useremo anche per evitare confusione con le \textit{dentry} del kernel di
543   cui si parlava in \secref{sec:file_vfs}).
544
545 \item Come mostrato in \curfig\ si possono avere più voci che puntano allo
546   stesso \textit{inode}. Ogni \textit{inode} ha un contatore che contiene il
547   numero di riferimenti (\textit{link count}) che sono stati fatti ad esso;
548   solo quando questo contatore si annulla i dati del file vengono
549   effettivamente rimossi dal disco. Per questo la funzione per cancellare un
550   file si chiama \func{unlink}, ed in realtà non cancella affatto i dati del
551   file, ma si limita a eliminare la relativa voce da una directory e
552   decrementare il numero di riferimenti nell'\textit{inode}.
553
554 \item Il numero di \textit{inode} nella voce si riferisce ad un \textit{inode}
555   nello stesso filesystem e non ci può essere una directory che contiene
556   riferimenti ad \textit{inodes} relativi ad altri filesystem. Questo limita
557   l'uso del comando \cmd{ln} (che crea una nuova voce per un file
558   esistente, con la funzione \func{link}) al filesystem corrente.
559
560 \item Quando si cambia nome ad un file senza cambiare filesystem il contenuto
561   del file non deve essere spostato, viene semplicemente creata una nuova voce
562   per l'\textit{inode} in questione e rimossa la vecchia (questa è la modalità
563   in cui opera normalmente il comando \cmd{mv} attraverso la funzione
564   \func{rename}).
565
566 \end{enumerate}
567
568 Infine è bene avere presente che, essendo file pure loro, esiste un numero di
569 riferimenti anche per le directory; per cui se a partire dalla situazione
570 mostrata in \curfig\ creiamo una nuova directory \file{img} nella directory
571 \file{gapil}: avremo una situazione come quella in \nfig, dove per chiarezza
572 abbiamo aggiunto dei numeri di inode.
573
574 \begin{figure}[htb]
575   \centering 
576   \includegraphics[width=12cm]{img/dir_links}
577   \caption{Organizzazione dei link per le directory}
578   \label{fig:file_dirs_link}
579 \end{figure}
580
581 La nuova directory avrà allora un numero di riferimenti pari a due, in quanto
582 è referenziata dalla directory da cui si era partiti (in cui è inserita la
583 nuova voce che fa riferimento a \file{img}) e dalla voce \file{.}
584 che è sempre inserita in ogni directory; questo vale sempre per ogni directory
585 che non contenga a sua volta altre directory. Al contempo la directory da
586 cui si era partiti avrà un numero di riferiementi di almeno tre, in quanto
587 adesso sarà referenziata anche dalla voce \file{..} di \file{img}.
588
589
590 \subsection{Il filesystem \textsl{ext2}}
591 \label{sec:file_ext2}
592
593 Il filesystem standard usato da Linux è il cosiddetto \textit{second extended
594   filesystem}, identificato dalla sigla \acr{ext2}. Esso supporta tutte le
595 caratteristiche di un filesystem standard Unix, è in grado di gestire nomi di
596 file lunghi (256 caratteri, estendibili a 1012), una dimensione fino a 4~Tb.
597
598 Oltre alle caratteristiche standard \acr{ext2} fornisce alcune estensioni che
599 non sono presenti sugli altri filesystem Unix, le cui principali sono le
600 seguenti:
601 \begin{itemize}
602 \item i \textit{file attributes} consentono di modificare il comportamento del
603   kernel quando agisce su gruppi di file. Possono essere settati su file e
604   directory e in quest'ultimo caso i nuovi file creati nella directory
605   ereditano i suoi attributi.
606 \item sono supportate entrambe le semantiche di BSD e SVr4 come opzioni di
607   montaggio. La semantica BSD comporta che i file in una directory sono creati
608   con lo stesso identificatore di gruppo della directory che li contiene. La
609   semantica SVr4 comporta che i file vengono creati con l'identificatore del
610   gruppo primario del processo, eccetto il caso in cui la directory ha il bit
611   di \acr{sgid} settato (per una descrizione dettagliata del significato di
612   questi termini si veda \secref{sec:file_access_control}), nel qual caso file
613   e subdirectory ereditano sia il \acr{gid} che lo \acr{sgid}.
614 \item l'amministratore può scegliere la dimensione dei blocchi del filesystem
615   in fase di creazione, a seconda delle sue esigenze (blocchi più grandi
616   permettono un accesso più veloce, ma sprecano più spazio disco).
617 \item il filesystem implementa link simbolici veloci, in cui il nome del file
618   non è salvato su un blocco, ma tenuto all'interno dell'inode (evitando
619   letture multiple e spreco di spazio), non tutti i nomi però possono essere
620   gestiti così per limiti di spazio (il limite è 60 caratteri). 
621 \item vengono supportati i file immutabili (che possono solo essere letti) per
622   la protezione di file di configurazione sensibili, o file
623   \textit{append-only} che possono essere aperti in scrittura solo per
624   aggiungere dati (caratteristica utilizzabile per la protezione dei file di
625   log).
626 \end{itemize}
627
628 La struttura di \acr{ext2} è stata ispirata a quella del filesystem di BSD:
629 un filesystem è composto da un insieme di blocchi, la struttura generale è
630 quella riportata in \figref{fig:file_filesys_detail}, in cui la partizione
631 è divisa in gruppi di blocchi.
632
633 Ciascun gruppo di blocchi contiene una copia delle informazioni essenziali del
634 filesystem (superblock e descrittore del filesystem sono quindi ridondati) per
635 una maggiore affidabilità e possibilità di recupero in caso di corruzione del
636 superblock principale.
637
638 \begin{figure}[htb]
639   \centering
640   \includegraphics[width=9cm]{img/dir_struct}  
641   \caption{Struttura delle directory nel \textit{second extented filesystem}.}
642   \label{fig:file_ext2_dirs}
643 \end{figure}
644
645 L'utilizzo di raggruppamenti di blocchi ha inoltre degli effetti positivi nelle
646 prestazioni dato che viene ridotta la distanza fra i dati e la tabella degli
647 inode. 
648
649 Le directory sono implementate come una linked list con voci di dimensione
650 variabile. Ciascuna voce della lista contiene il numero di inode, la sua
651 lunghezza, il nome del file e la sua lunghezza, secondo lo schema in \curfig;
652 in questo modo è possibile implementare nomi per i file anche molto lunghi
653 (fino a 1024 caratteri) senza sprecare spazio disco.
654
655
656
657
658 %%% Local Variables: 
659 %%% mode: latex
660 %%% TeX-master: "gapil"
661 %%% End: